Oneboxes should use a sorted array for ordering, not a hash.

This commit is contained in:
Robin Ward 2013-03-21 11:47:01 -04:00
parent e3d30f1366
commit 9d4ecd7ef8
2 changed files with 16 additions and 12 deletions

View File

@ -9,7 +9,7 @@ Dir["#{Rails.root}/lib/oneboxer/*_onebox.rb"].each {|f|
module Oneboxer module Oneboxer
extend Oneboxer::Base extend Oneboxer::Base
Dir["#{Rails.root}/lib/oneboxer/*_onebox.rb"].each do |f| Dir["#{Rails.root}/lib/oneboxer/*_onebox.rb"].sort.each do |f|
add_onebox "Oneboxer::#{Pathname.new(f).basename.to_s.gsub(/\.rb$/, '').classify}".constantize add_onebox "Oneboxer::#{Pathname.new(f).basename.to_s.gsub(/\.rb$/, '').classify}".constantize
end end
@ -19,9 +19,12 @@ module Oneboxer
# Return a oneboxer for a given URL # Return a oneboxer for a given URL
def self.onebox_for_url(url) def self.onebox_for_url(url)
matchers.each do |regexp, oneboxer| matchers.each do |matcher|
regexp = matcher.regexp
klass = matcher.klass
regexp = regexp.call if regexp.class == Proc regexp = regexp.call if regexp.class == Proc
return oneboxer.new(url) if url =~ regexp return klass.new(url) if url =~ regexp
end end
nil nil
end end

View File

@ -28,22 +28,23 @@ module Oneboxer
end end
end end
module Base class Matcher
attr_reader :regexp, :klass
def matchers def initialize(klass)
@matchers ||= {} @klass = klass
@matchers @regexp = klass.regexp
end end
end
# Add a matcher module Base
def add_matcher(regexp, klass) def matchers
matchers[regexp] = klass @matchers ||= []
end end
def add_onebox(klass) def add_onebox(klass)
matchers[klass.regexp] = klass matchers << Matcher.new(klass)
end end
end end
end end