lib/request_log_analyzer.rb in wvanbergen-request-log-analyzer-1.2.9 vs lib/request_log_analyzer.rb in wvanbergen-request-log-analyzer-1.3.0

- old
+ new

@@ -9,35 +9,32 @@ # - The actual application resides in the RequestLogAnalyzer::Controller class. module RequestLogAnalyzer # The current version of request-log-analyzer. # This will be diplayed in output reports etc. - VERSION = "1.2.9" - + VERSION = "1.3.0" + # Loads constants in the RequestLogAnalyzer namespace using self.load_default_class_file(base, const) # <tt>const</tt>:: The constant that is not yet loaded in the RequestLogAnalyzer namespace. This should be passed as a string or symbol. def self.const_missing(const) load_default_class_file(RequestLogAnalyzer, const) end - + # Loads constants that reside in the RequestLogAnalyzer tree using the constant name # and its base constant to determine the filename. # <tt>base</tt>:: The base constant to load the constant from. This should be Foo when the constant Foo::Bar is being loaded. # <tt>const</tt>:: The constant to load from the base constant as a string or symbol. This should be 'Bar' or :Bar when the constant Foo::Bar is being loaded. def self.load_default_class_file(base, const) - path = to_underscore(base.to_s) - basename = to_underscore(const.to_s) - filename = "#{File.dirname(__FILE__)}/#{path}/#{basename}" - require filename + require "#{to_underscore("#{base.name}::#{const}")}" base.const_get(const) end # Convert a string/symbol in camelcase (RequestLogAnalyzer::Controller) to underscores (request_log_analyzer/controller) # This function can be used to load the file (using require) in which the given constant is defined. # <tt>str</tt>:: The string to convert in the following format: <tt>ModuleName::ClassName</tt> def self.to_underscore(str) str.to_s.gsub(/::/, '/').gsub(/([A-Z]+)([A-Z][a-z])/,'\1_\2').gsub(/([a-z\d])([A-Z])/,'\1_\2').tr("-", "_").downcase - end + end # Convert a string/symbol in underscores (<tt>request_log_analyzer/controller</tt>) to camelcase # (<tt>RequestLogAnalyzer::Controller</tt>). This can be used to find the class that is defined in a given filename. # <tt>str</tt>:: The string to convert in the following format: <tt>module_name/class_name</tt> def self.to_camelcase(str)