lib/ezframe/route.rb in ezframe-0.2.0 vs lib/ezframe/route.rb in ezframe-0.3.0
- old
+ new
@@ -2,10 +2,13 @@
class Route
class << self
def choose(request, route_h = nil)
path_parts = request.path_info.split("/").drop(1)
route_h ||= Config[:route].deep_dup
+ unless route_h
+ raise "Config[:route] is not defined. It should be defined in config/route.yml"
+ end
# puts "config=#{Config[:route]}, route_h=#{route_h}"
args = {}
opts = {}
class_a = []
# p path_parts
@@ -20,17 +23,17 @@
end
# URLを解析して、クラスの決定とIDの取得を行う
while path_parts.length > 0
part = path_parts.shift
# break if part.empty?
- # Logger.info "part=#{part}, route_h=#{route_h.inspect}"
+ # EzLog.info "part=#{part}, route_h=#{route_h.inspect}"
if route_h.has_key?(part.to_sym)
- # Logger.info "has_route: #{part}"
+ # EzLog.info "has_route: #{part}"
class_a.push(part)
if path_parts[0].to_i > 0
args[part.to_sym] = val = path_parts.shift
- # Logger.info "value: part=#{part}, val=#{val}"
+ # EzLog.info "value: part=#{part}, val=#{val}"
end
route_h = route_h[part.to_sym]
break if route_h.nil?
opts = {}
route_h.keys.compact.each do |rkey|
@@ -39,19 +42,19 @@
opts[opt_key.to_sym] = route_h[rkey]
end
end
else
# routeに無ければ、メソッドを探す
- # Logger.info "no_route: #{part}"
+ # EzLog.info "no_route: #{part}"
klass = get_class(class_a[-1])
return [ 404 ] unless klass
instance = klass.new
method_name = make_method_name(part, request.request_method)
if instance.respond_to?(method_name)
return [instance, method_name, args, opts]
else
- Logger.info "undefined method: #{klass}.#{method_name}: full path=#{request.path_info}"
+ EzLog.info "undefined method: #{klass}.#{method_name}: full path=#{request.path_info}"
end
end
end
# 最後にメソッド名が無い場合はpublic_default_#{method}を実行。
#puts "class_a=#{class_a}"
@@ -61,22 +64,22 @@
part = path_parts.shift
else
part = "default"
end
method_name = make_method_name(part, request.request_method)
- #Logger.info "method_name=#{method_name}"
+ #EzLog.info "method_name=#{method_name}"
instance = klass.new
if instance.respond_to?(method_name)
return [instance, method_name, args, opts]
end
return [ 404 ]
end
# ページクラスの階層を辿る
def get_path(class_snake, route_h = nil)
route_h = Config[:route] unless route_h
- # Logger.info "get_path: route_h=#{route_h}"
+ # EzLog.info "get_path: route_h=#{route_h}"
@get_path_found_it = nil
route =_scan_route(class_snake, route_h.deep_dup)
return route.reverse if route
return nil
end
@@ -104,14 +107,14 @@
def make_method_name(base_name, method = "get")
return ["public", base_name, method.downcase].join("_")
end
def get_class(keys)
- # Logger.info "get_class: #{keys.inspect}"
+ # EzLog.info "get_class: #{keys.inspect}"
return nil unless keys
keys = [ keys ] if keys.is_a?(String)
klass = (%w[Ezframe] + keys.map { |k| k.to_s.to_camel }).join("::")
- # Logger.info "get_class: #{klass}"
+ # EzLog.info "get_class: #{klass}"
if Object.const_defined?(klass)
return Object.const_get(klass)
else
raise "get_class: undefined class: #{klass}"
end