Remove param parsing with regex since Radix has state-machine implementation which is a way faster
This commit is contained in:
parent
afdb6fb793
commit
ce1f595c5d
3 changed files with 13 additions and 35 deletions
|
@ -30,16 +30,15 @@ class Kemal::Handler < HTTP::Handler
|
||||||
lookup = @tree.find radix_path(context.request.override_method as String, context.request.path)
|
lookup = @tree.find radix_path(context.request.override_method as String, context.request.path)
|
||||||
if lookup.found?
|
if lookup.found?
|
||||||
route = lookup.payload as Route
|
route = lookup.payload as Route
|
||||||
if route.match?(context.request)
|
context.request.url_params = lookup.params
|
||||||
begin
|
begin
|
||||||
context.response.content_type = "text/html"
|
context.response.content_type = "text/html"
|
||||||
body = route.handler.call(context).to_s
|
body = route.handler.call(context).to_s
|
||||||
context.response.print body
|
context.response.print body
|
||||||
return context
|
return context
|
||||||
rescue ex
|
rescue ex
|
||||||
Kemal::Logger::INSTANCE.write "Exception: #{ex.to_s}\n"
|
Kemal::Logger::INSTANCE.write "Exception: #{ex.to_s}\n"
|
||||||
return render_500(context, ex.to_s)
|
return render_500(context, ex.to_s)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
# Render 404 unless a route matches
|
# Render 404 unless a route matches
|
||||||
|
|
|
@ -35,14 +35,11 @@ class Kemal::ParamParser
|
||||||
parse_part(@request.query)
|
parse_part(@request.query)
|
||||||
end
|
end
|
||||||
|
|
||||||
# Ditto: This needs memoization without the huge AllParamTypes union :|
|
|
||||||
def parse_url_params
|
def parse_url_params
|
||||||
if @request.url_params
|
params = @request.url_params
|
||||||
url_params = @request.url_params.not_nil!
|
if params
|
||||||
name_table = url_params.regex.name_table
|
params.not_nil!.each do |key, value|
|
||||||
url_params.size.times do |i|
|
@params[key] = value
|
||||||
name = (name_table.fetch(i + 1) { i + 1 }) as String
|
|
||||||
@params[name] = url_params[i + 1]
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -6,17 +6,6 @@ class Kemal::Route
|
||||||
getter method
|
getter method
|
||||||
|
|
||||||
def initialize(@method, @path, &@handler : HTTP::Server::Context -> _)
|
def initialize(@method, @path, &@handler : HTTP::Server::Context -> _)
|
||||||
@compiled_regex = pattern_to_regex(@path)
|
|
||||||
end
|
|
||||||
|
|
||||||
def match?(request)
|
|
||||||
self.class.check_for_method_override!(request)
|
|
||||||
return nil unless request.override_method == @method
|
|
||||||
return true if request.path.not_nil!.includes?(':') && request.path.not_nil! == @path
|
|
||||||
request.path.not_nil!.match(@compiled_regex) do |url_params|
|
|
||||||
request.url_params = url_params
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Checks if request params contain _method param to override request incoming method
|
# Checks if request params contain _method param to override request incoming method
|
||||||
|
@ -36,11 +25,4 @@ class Kemal::Route
|
||||||
override_method = override_method.upcase
|
override_method = override_method.upcase
|
||||||
return (override_method == "PUT" || override_method == "PATCH" || override_method == "DELETE")
|
return (override_method == "PUT" || override_method == "PATCH" || override_method == "DELETE")
|
||||||
end
|
end
|
||||||
|
|
||||||
private def pattern_to_regex(pattern)
|
|
||||||
pattern = pattern.gsub(/\:(?<param>\w+)/) do |_, match|
|
|
||||||
"(?<#{match["param"]}>.*)"
|
|
||||||
end
|
|
||||||
Regex.new "^#{pattern}/?$"
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue