Ignore db/structure.sql
[rails.git] / vendor / plugins / http_accept_language / lib / http_accept_language.rb
1 module HttpAcceptLanguage
2
3   # Returns a sorted array based on user preference in HTTP_ACCEPT_LANGUAGE.
4   # Browsers send this HTTP header, so don't think this is holy.
5   #
6   # Example:
7   #
8   #   request.user_preferred_languages
9   #   # => [ 'nl-NL', 'nl-BE', 'nl', 'en-US', 'en' ]
10   #
11   def user_preferred_languages
12     @user_preferred_languages ||= env['HTTP_ACCEPT_LANGUAGE'].split(',').collect do |l|
13       l += ';q=1.0' unless l =~ /;q=\d+\.\d+$/
14       l.split(';q=')
15     end.sort do |x,y|
16       raise "Not correctly formatted" unless x.first =~ /^[a-z\-]+$/i
17       y.last.to_f <=> x.last.to_f
18     end.collect do |l|
19       l.first.downcase.gsub(/-[a-z]+$/i) { |x| x.upcase }
20     end
21   rescue # Just rescue anything if the browser messed up badly.
22     []
23   end
24
25   # Sets the user languages preference, overiding the browser
26   #
27   def user_preferred_languages=(languages)
28     @user_preferred_languages = languages
29   end
30
31   # Finds the locale specifically requested by the browser.
32   #
33   # Example:
34   #
35   #   request.preferred_language_from I18n.available_locales
36   #   # => 'nl'
37   #
38   def preferred_language_from(array)
39     (user_preferred_languages & array.collect { |i| i.to_s }).first
40   end
41
42   # Returns the first of the user_preferred_languages that is compatible
43   # with the available locales. Ignores region.
44   #
45   # Example:
46   #
47   #   request.compatible_language_from I18n.available_locales
48   #
49   def compatible_language_from(array)
50     user_preferred_languages.find do |x|
51       array.find { |y| y.to_s == x.to_s } ||
52       array.find { |y| y.to_s =~ /^#{Regexp.escape(x.to_s)}-/ }
53     end
54   end
55
56 end