mirror of
https://github.com/github/rails.git
synced 2026-04-26 03:00:59 -04:00
Merge branch 'master' of git@github.com:rails/rails
This commit is contained in:
@@ -998,7 +998,7 @@ module ActionController #:nodoc:
|
||||
# As you can infer from the example, this is mostly useful for situations where you want to centralize dynamic decisions about the
|
||||
# urls as they stem from the business domain. Please note that any individual url_for call can always override the defaults set
|
||||
# by this method.
|
||||
def default_url_options(options) #:doc:
|
||||
def default_url_options(options = nil)
|
||||
end
|
||||
|
||||
# Redirects the browser to the target specified in +options+. This parameter can take one of three forms:
|
||||
|
||||
@@ -61,9 +61,9 @@ module ActionController
|
||||
# if they're using foo_url(:id=>2) it's one
|
||||
# argument, but we don't want to generate /foos/id2
|
||||
if number_of_arguments == 1
|
||||
"(!defined?(default_url_options) || default_url_options(nil).blank?) && defined?(request) && request && args.size == 1 && !args.first.is_a?(Hash)"
|
||||
"(!defined?(default_url_options) || default_url_options.blank?) && defined?(request) && request && args.size == 1 && !args.first.is_a?(Hash)"
|
||||
else
|
||||
"(!defined?(default_url_options) || default_url_options(nil).blank?) && defined?(request) && request && args.size == #{number_of_arguments}"
|
||||
"(!defined?(default_url_options) || default_url_options.blank?) && defined?(request) && request && args.size == #{number_of_arguments}"
|
||||
end
|
||||
end
|
||||
|
||||
@@ -98,7 +98,7 @@ module ActionController
|
||||
# argument
|
||||
class PositionalArgumentsWithAdditionalParams < PositionalArguments
|
||||
def guard_condition
|
||||
"(!defined?(default_url_options) || default_url_options(nil).blank?) && defined?(request) && request && args.size == #{route.segment_keys.size + 1} && !args.last.has_key?(:anchor) && !args.last.has_key?(:port) && !args.last.has_key?(:host)"
|
||||
"(!defined?(default_url_options) || default_url_options.blank?) && defined?(request) && request && args.size == #{route.segment_keys.size + 1} && !args.last.has_key?(:anchor) && !args.last.has_key?(:port) && !args.last.has_key?(:host)"
|
||||
end
|
||||
|
||||
# This case uses almost the same code as positional arguments,
|
||||
|
||||
@@ -614,23 +614,27 @@ module ActionView
|
||||
end
|
||||
|
||||
def tag_name
|
||||
"#{@object_name}[#{@method_name}]"
|
||||
"#{@object_name}[#{sanitized_method_name}]"
|
||||
end
|
||||
|
||||
def tag_name_with_index(index)
|
||||
"#{@object_name}[#{index}][#{@method_name}]"
|
||||
"#{@object_name}[#{index}][#{sanitized_method_name}]"
|
||||
end
|
||||
|
||||
def tag_id
|
||||
"#{sanitized_object_name}_#{@method_name}"
|
||||
"#{sanitized_object_name}_#{sanitized_method_name}"
|
||||
end
|
||||
|
||||
def tag_id_with_index(index)
|
||||
"#{sanitized_object_name}_#{index}_#{@method_name}"
|
||||
"#{sanitized_object_name}_#{index}_#{sanitized_method_name}"
|
||||
end
|
||||
|
||||
def sanitized_object_name
|
||||
@object_name.gsub(/[^-a-zA-Z0-9:.]/, "_").sub(/_$/, "")
|
||||
@sanitized_object_name ||= @object_name.gsub(/[^-a-zA-Z0-9:.]/, "_").sub(/_$/, "")
|
||||
end
|
||||
|
||||
def sanitized_method_name
|
||||
@sanitized_method_name ||= @method_name.sub(/\?$/,"")
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
@@ -52,7 +52,7 @@ class DefaultUrlOptionsController < ActionController::Base
|
||||
def default_url_options_action
|
||||
end
|
||||
|
||||
def default_url_options(options)
|
||||
def default_url_options(options = nil)
|
||||
{ :host => 'www.override.com', :action => 'new', :bacon => 'chunky' }
|
||||
end
|
||||
end
|
||||
@@ -167,4 +167,17 @@ class DefaultUrlOptionsTest < Test::Unit::TestCase
|
||||
ensure
|
||||
ActionController::Routing::Routes.load!
|
||||
end
|
||||
end
|
||||
|
||||
class EnsureNamedRoutesWorksTicket22BugTest < Test::Unit::TestCase
|
||||
def test_named_routes_still_work
|
||||
ActionController::Routing::Routes.draw do |map|
|
||||
map.resources :things
|
||||
end
|
||||
EmptyController.send :include, ActionController::UrlWriter
|
||||
|
||||
assert_equal '/things', EmptyController.new.send(:things_path)
|
||||
ensure
|
||||
ActionController::Routing::Routes.load!
|
||||
end
|
||||
end
|
||||
@@ -6,6 +6,7 @@ silence_warnings do
|
||||
alias_method :title_before_type_cast, :title unless respond_to?(:title_before_type_cast)
|
||||
alias_method :body_before_type_cast, :body unless respond_to?(:body_before_type_cast)
|
||||
alias_method :author_name_before_type_cast, :author_name unless respond_to?(:author_name_before_type_cast)
|
||||
alias_method :secret?, :secret
|
||||
|
||||
def new_record=(boolean)
|
||||
@new_record = boolean
|
||||
@@ -71,10 +72,12 @@ class FormHelperTest < ActionView::TestCase
|
||||
'<label class="title_label" for="post_title">Title</label>',
|
||||
label("post", "title", nil, :class => 'title_label')
|
||||
)
|
||||
assert_dom_equal('<label for="post_secret">Secret?</label>', label("post", "secret?"))
|
||||
end
|
||||
|
||||
def test_label_with_symbols
|
||||
assert_dom_equal('<label for="post_title">Title</label>', label(:post, :title))
|
||||
assert_dom_equal('<label for="post_secret">Secret?</label>', label(:post, :secret?))
|
||||
end
|
||||
|
||||
def test_label_with_for_attribute_as_symbol
|
||||
@@ -140,6 +143,8 @@ class FormHelperTest < ActionView::TestCase
|
||||
def test_hidden_field
|
||||
assert_dom_equal '<input id="post_title" name="post[title]" type="hidden" value="Hello World" />',
|
||||
hidden_field("post", "title")
|
||||
assert_dom_equal '<input id="post_secret" name="post[secret]" type="hidden" value="1" />',
|
||||
hidden_field("post", "secret?")
|
||||
end
|
||||
|
||||
def test_hidden_field_with_escapes
|
||||
@@ -172,6 +177,10 @@ class FormHelperTest < ActionView::TestCase
|
||||
'<input checked="checked" id="post_secret" name="post[secret]" type="checkbox" value="1" /><input name="post[secret]" type="hidden" value="0" />',
|
||||
check_box("post", "secret")
|
||||
)
|
||||
assert_dom_equal(
|
||||
'<input checked="checked" id="post_secret" name="post[secret]" type="checkbox" value="1" /><input name="post[secret]" type="hidden" value="0" />',
|
||||
check_box("post", "secret?")
|
||||
)
|
||||
end
|
||||
|
||||
def test_check_box_with_explicit_checked_and_unchecked_values
|
||||
|
||||
@@ -295,6 +295,12 @@ module ActiveRecord
|
||||
def structure_dump
|
||||
end
|
||||
|
||||
def dump_schema_information #:nodoc:
|
||||
sm_table = ActiveRecord::Migrator.schema_migrations_table_name
|
||||
migrated = select_values("SELECT version FROM #{sm_table}")
|
||||
migrated.map { |v| "INSERT INTO #{sm_table} (version) VALUES ('#{v}');" }.join("\n")
|
||||
end
|
||||
|
||||
# Should not be called normally, but this operation is non-destructive.
|
||||
# The migrations module handles this automatically.
|
||||
def initialize_schema_migrations_table
|
||||
|
||||
@@ -1,5 +1,7 @@
|
||||
*SVN*
|
||||
|
||||
* Added Ruby 1.8 implementation of Process.daemon
|
||||
|
||||
* Duration #since and #ago with no argument (e.g., 5.days.ago) return TimeWithZone when config.time_zone is set. Introducing Time.current, which returns Time.zone.now if config.time_zone is set, otherwise just returns Time.now [Geoff Buesing]
|
||||
|
||||
* Time#since behaves correctly when passed a Duration. Closes #11527 [kemiller]
|
||||
|
||||
@@ -2,14 +2,6 @@ module Kernel
|
||||
# Turns the current script into a daemon process that detaches from the console.
|
||||
# It can be shut down with a TERM signal.
|
||||
def daemonize
|
||||
exit if fork # Parent exits, child continues.
|
||||
Process.setsid # Become session leader.
|
||||
exit if fork # Zap session leader. See [1].
|
||||
Dir.chdir "/" # Release old working directory.
|
||||
File.umask 0000 # Ensure sensible umask. Adjust as needed.
|
||||
STDIN.reopen "/dev/null" # Free file descriptors and
|
||||
STDOUT.reopen "/dev/null", "a" # point them somewhere sensible.
|
||||
STDERR.reopen STDOUT # STDOUT/ERR should better go to a logfile.
|
||||
trap("TERM") { exit }
|
||||
Process.daemon
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
1
activesupport/lib/active_support/core_ext/process.rb
Normal file
1
activesupport/lib/active_support/core_ext/process.rb
Normal file
@@ -0,0 +1 @@
|
||||
require 'active_support/core_ext/process/daemon'
|
||||
25
activesupport/lib/active_support/core_ext/process/daemon.rb
Normal file
25
activesupport/lib/active_support/core_ext/process/daemon.rb
Normal file
@@ -0,0 +1,25 @@
|
||||
if RUBY_VERSION < "1.9"
|
||||
module Process
|
||||
def self.daemon(nochdir = nil, noclose = nil)
|
||||
exit if fork # Parent exits, child continues.
|
||||
Process.setsid # Become session leader.
|
||||
exit if fork # Zap session leader. See [1].
|
||||
|
||||
unless nochdir
|
||||
Dir.chdir "/" # Release old working directory.
|
||||
end
|
||||
|
||||
File.umask 0000 # Ensure sensible umask. Adjust as needed.
|
||||
|
||||
unless noclose
|
||||
STDIN.reopen "/dev/null" # Free file descriptors and
|
||||
STDOUT.reopen "/dev/null", "a" # point them somewhere sensible.
|
||||
STDERR.reopen '/dev/null', 'a'
|
||||
end
|
||||
|
||||
trap("TERM") { exit }
|
||||
|
||||
return 0
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -18,6 +18,12 @@ module ActiveSupport
|
||||
pair = assoc(key)
|
||||
pair ? pair.last : nil
|
||||
end
|
||||
|
||||
def delete(key)
|
||||
pair = assoc(key)
|
||||
pair ? array_index = index(pair) : nil
|
||||
array_index ? delete_at(array_index).last : nil
|
||||
end
|
||||
|
||||
def keys
|
||||
collect { |key, value| key }
|
||||
|
||||
@@ -1,149 +1,152 @@
|
||||
class TimeZone
|
||||
# Keys are Rails TimeZone names, values are TZInfo identifiers
|
||||
MAPPING = {
|
||||
"International Date Line West" => "Pacific/Midway",
|
||||
"Midway Island" => "Pacific/Midway",
|
||||
"Samoa" => "Pacific/Pago_Pago",
|
||||
"Hawaii" => "Pacific/Honolulu",
|
||||
"Alaska" => "America/Juneau",
|
||||
"Pacific Time (US & Canada)" => "America/Los_Angeles",
|
||||
"Tijuana" => "America/Tijuana",
|
||||
"Mountain Time (US & Canada)" => "America/Denver",
|
||||
"Arizona" => "America/Phoenix",
|
||||
"Chihuahua" => "America/Chihuahua",
|
||||
"Mazatlan" => "America/Mazatlan",
|
||||
"Central Time (US & Canada)" => "America/Chicago",
|
||||
"Saskatchewan" => "America/Regina",
|
||||
"Guadalajara" => "America/Mexico_City",
|
||||
"Mexico City" => "America/Mexico_City",
|
||||
"Monterrey" => "America/Monterrey",
|
||||
"Central America" => "America/Guatemala",
|
||||
"Eastern Time (US & Canada)" => "America/New_York",
|
||||
"Indiana (East)" => "America/Indiana/Indianapolis",
|
||||
"Bogota" => "America/Bogota",
|
||||
"Lima" => "America/Lima",
|
||||
"Quito" => "America/Lima",
|
||||
"Atlantic Time (Canada)" => "America/Halifax",
|
||||
"Caracas" => "America/Caracas",
|
||||
"La Paz" => "America/La_Paz",
|
||||
"Santiago" => "America/Santiago",
|
||||
"Newfoundland" => "America/St_Johns",
|
||||
"Brasilia" => "America/Argentina/Buenos_Aires",
|
||||
"Buenos Aires" => "America/Argentina/Buenos_Aires",
|
||||
"Georgetown" => "America/Argentina/San_Juan",
|
||||
"Greenland" => "America/Godthab",
|
||||
"Mid-Atlantic" => "Atlantic/South_Georgia",
|
||||
"Azores" => "Atlantic/Azores",
|
||||
"Cape Verde Is." => "Atlantic/Cape_Verde",
|
||||
"Dublin" => "Europe/Dublin",
|
||||
"Edinburgh" => "Europe/Dublin",
|
||||
"Lisbon" => "Europe/Lisbon",
|
||||
"London" => "Europe/London",
|
||||
"Casablanca" => "Africa/Casablanca",
|
||||
"Monrovia" => "Africa/Monrovia",
|
||||
"UTC" => "Etc/UTC",
|
||||
"Belgrade" => "Europe/Belgrade",
|
||||
"Bratislava" => "Europe/Bratislava",
|
||||
"Budapest" => "Europe/Budapest",
|
||||
"Ljubljana" => "Europe/Ljubljana",
|
||||
"Prague" => "Europe/Prague",
|
||||
"Sarajevo" => "Europe/Sarajevo",
|
||||
"Skopje" => "Europe/Skopje",
|
||||
"Warsaw" => "Europe/Warsaw",
|
||||
"Zagreb" => "Europe/Zagreb",
|
||||
"Brussels" => "Europe/Brussels",
|
||||
"Copenhagen" => "Europe/Copenhagen",
|
||||
"Madrid" => "Europe/Madrid",
|
||||
"Paris" => "Europe/Paris",
|
||||
"Amsterdam" => "Europe/Amsterdam",
|
||||
"Berlin" => "Europe/Berlin",
|
||||
"Bern" => "Europe/Berlin",
|
||||
"Rome" => "Europe/Rome",
|
||||
"Stockholm" => "Europe/Stockholm",
|
||||
"Vienna" => "Europe/Vienna",
|
||||
"West Central Africa" => "Africa/Algiers",
|
||||
"Bucharest" => "Europe/Bucharest",
|
||||
"Cairo" => "Africa/Cairo",
|
||||
"Helsinki" => "Europe/Helsinki",
|
||||
"Kyev" => "Europe/Kiev",
|
||||
"Riga" => "Europe/Riga",
|
||||
"Sofia" => "Europe/Sofia",
|
||||
"Tallinn" => "Europe/Tallinn",
|
||||
"Vilnius" => "Europe/Vilnius",
|
||||
"Athens" => "Europe/Athens",
|
||||
"Istanbul" => "Europe/Istanbul",
|
||||
"Minsk" => "Europe/Minsk",
|
||||
"Jerusalem" => "Asia/Jerusalem",
|
||||
"Harare" => "Africa/Harare",
|
||||
"Pretoria" => "Africa/Johannesburg",
|
||||
"Moscow" => "Europe/Moscow",
|
||||
"St. Petersburg" => "Europe/Moscow",
|
||||
"Volgograd" => "Europe/Moscow",
|
||||
"Kuwait" => "Asia/Kuwait",
|
||||
"Riyadh" => "Asia/Riyadh",
|
||||
"Nairobi" => "Africa/Nairobi",
|
||||
"Baghdad" => "Asia/Baghdad",
|
||||
"Tehran" => "Asia/Tehran",
|
||||
"Abu Dhabi" => "Asia/Muscat",
|
||||
"Muscat" => "Asia/Muscat",
|
||||
"Baku" => "Asia/Baku",
|
||||
"Tbilisi" => "Asia/Tbilisi",
|
||||
"Yerevan" => "Asia/Yerevan",
|
||||
"Kabul" => "Asia/Kabul",
|
||||
"Ekaterinburg" => "Asia/Yekaterinburg",
|
||||
"Islamabad" => "Asia/Karachi",
|
||||
"Karachi" => "Asia/Karachi",
|
||||
"Tashkent" => "Asia/Tashkent",
|
||||
"Chennai" => "Asia/Kolkata",
|
||||
"Kolkata" => "Asia/Kolkata",
|
||||
"Mumbai" => "Asia/Kolkata",
|
||||
"New Delhi" => "Asia/Kolkata",
|
||||
"Kathmandu" => "Asia/Katmandu",
|
||||
"Astana" => "Asia/Dhaka",
|
||||
"Dhaka" => "Asia/Dhaka",
|
||||
"Sri Jayawardenepura" => "Asia/Dhaka",
|
||||
"Almaty" => "Asia/Almaty",
|
||||
"Novosibirsk" => "Asia/Novosibirsk",
|
||||
"Rangoon" => "Asia/Rangoon",
|
||||
"Bangkok" => "Asia/Bangkok",
|
||||
"Hanoi" => "Asia/Bangkok",
|
||||
"Jakarta" => "Asia/Jakarta",
|
||||
"Krasnoyarsk" => "Asia/Krasnoyarsk",
|
||||
"Beijing" => "Asia/Shanghai",
|
||||
"Chongqing" => "Asia/Chongqing",
|
||||
"Hong Kong" => "Asia/Hong_Kong",
|
||||
"Urumqi" => "Asia/Urumqi",
|
||||
"Kuala Lumpur" => "Asia/Kuala_Lumpur",
|
||||
"Singapore" => "Asia/Singapore",
|
||||
"Taipei" => "Asia/Taipei",
|
||||
"Perth" => "Australia/Perth",
|
||||
"Irkutsk" => "Asia/Irkutsk",
|
||||
"Ulaan Bataar" => "Asia/Ulaanbaatar",
|
||||
"Seoul" => "Asia/Seoul",
|
||||
"Osaka" => "Asia/Tokyo",
|
||||
"Sapporo" => "Asia/Tokyo",
|
||||
"Tokyo" => "Asia/Tokyo",
|
||||
"Yakutsk" => "Asia/Yakutsk",
|
||||
"Darwin" => "Australia/Darwin",
|
||||
"Adelaide" => "Australia/Adelaide",
|
||||
"Canberra" => "Australia/Melbourne",
|
||||
"Melbourne" => "Australia/Melbourne",
|
||||
"Sydney" => "Australia/Sydney",
|
||||
"Brisbane" => "Australia/Brisbane",
|
||||
"Hobart" => "Australia/Hobart",
|
||||
"Vladivostok" => "Asia/Vladivostok",
|
||||
"Guam" => "Pacific/Guam",
|
||||
"Port Moresby" => "Pacific/Port_Moresby",
|
||||
"Magadan" => "Asia/Magadan",
|
||||
"Solomon Is." => "Asia/Magadan",
|
||||
"New Caledonia" => "Pacific/Noumea",
|
||||
"Fiji" => "Pacific/Fiji",
|
||||
"Kamchatka" => "Asia/Kamchatka",
|
||||
"Marshall Is." => "Pacific/Majuro",
|
||||
"Auckland" => "Pacific/Auckland",
|
||||
"Wellington" => "Pacific/Auckland",
|
||||
"Nuku'alofa" => "Pacific/Tongatapu"
|
||||
}
|
||||
unless const_defined?(:MAPPING)
|
||||
# Keys are Rails TimeZone names, values are TZInfo identifiers
|
||||
MAPPING = {
|
||||
"International Date Line West" => "Pacific/Midway",
|
||||
"Midway Island" => "Pacific/Midway",
|
||||
"Samoa" => "Pacific/Pago_Pago",
|
||||
"Hawaii" => "Pacific/Honolulu",
|
||||
"Alaska" => "America/Juneau",
|
||||
"Pacific Time (US & Canada)" => "America/Los_Angeles",
|
||||
"Tijuana" => "America/Tijuana",
|
||||
"Mountain Time (US & Canada)" => "America/Denver",
|
||||
"Arizona" => "America/Phoenix",
|
||||
"Chihuahua" => "America/Chihuahua",
|
||||
"Mazatlan" => "America/Mazatlan",
|
||||
"Central Time (US & Canada)" => "America/Chicago",
|
||||
"Saskatchewan" => "America/Regina",
|
||||
"Guadalajara" => "America/Mexico_City",
|
||||
"Mexico City" => "America/Mexico_City",
|
||||
"Monterrey" => "America/Monterrey",
|
||||
"Central America" => "America/Guatemala",
|
||||
"Eastern Time (US & Canada)" => "America/New_York",
|
||||
"Indiana (East)" => "America/Indiana/Indianapolis",
|
||||
"Bogota" => "America/Bogota",
|
||||
"Lima" => "America/Lima",
|
||||
"Quito" => "America/Lima",
|
||||
"Atlantic Time (Canada)" => "America/Halifax",
|
||||
"Caracas" => "America/Caracas",
|
||||
"La Paz" => "America/La_Paz",
|
||||
"Santiago" => "America/Santiago",
|
||||
"Newfoundland" => "America/St_Johns",
|
||||
"Brasilia" => "America/Argentina/Buenos_Aires",
|
||||
"Buenos Aires" => "America/Argentina/Buenos_Aires",
|
||||
"Georgetown" => "America/Argentina/San_Juan",
|
||||
"Greenland" => "America/Godthab",
|
||||
"Mid-Atlantic" => "Atlantic/South_Georgia",
|
||||
"Azores" => "Atlantic/Azores",
|
||||
"Cape Verde Is." => "Atlantic/Cape_Verde",
|
||||
"Dublin" => "Europe/Dublin",
|
||||
"Edinburgh" => "Europe/Dublin",
|
||||
"Lisbon" => "Europe/Lisbon",
|
||||
"London" => "Europe/London",
|
||||
"Casablanca" => "Africa/Casablanca",
|
||||
"Monrovia" => "Africa/Monrovia",
|
||||
"UTC" => "Etc/UTC",
|
||||
"Belgrade" => "Europe/Belgrade",
|
||||
"Bratislava" => "Europe/Bratislava",
|
||||
"Budapest" => "Europe/Budapest",
|
||||
"Ljubljana" => "Europe/Ljubljana",
|
||||
"Prague" => "Europe/Prague",
|
||||
"Sarajevo" => "Europe/Sarajevo",
|
||||
"Skopje" => "Europe/Skopje",
|
||||
"Warsaw" => "Europe/Warsaw",
|
||||
"Zagreb" => "Europe/Zagreb",
|
||||
"Brussels" => "Europe/Brussels",
|
||||
"Copenhagen" => "Europe/Copenhagen",
|
||||
"Madrid" => "Europe/Madrid",
|
||||
"Paris" => "Europe/Paris",
|
||||
"Amsterdam" => "Europe/Amsterdam",
|
||||
"Berlin" => "Europe/Berlin",
|
||||
"Bern" => "Europe/Berlin",
|
||||
"Rome" => "Europe/Rome",
|
||||
"Stockholm" => "Europe/Stockholm",
|
||||
"Vienna" => "Europe/Vienna",
|
||||
"West Central Africa" => "Africa/Algiers",
|
||||
"Bucharest" => "Europe/Bucharest",
|
||||
"Cairo" => "Africa/Cairo",
|
||||
"Helsinki" => "Europe/Helsinki",
|
||||
"Kyev" => "Europe/Kiev",
|
||||
"Riga" => "Europe/Riga",
|
||||
"Sofia" => "Europe/Sofia",
|
||||
"Tallinn" => "Europe/Tallinn",
|
||||
"Vilnius" => "Europe/Vilnius",
|
||||
"Athens" => "Europe/Athens",
|
||||
"Istanbul" => "Europe/Istanbul",
|
||||
"Minsk" => "Europe/Minsk",
|
||||
"Jerusalem" => "Asia/Jerusalem",
|
||||
"Harare" => "Africa/Harare",
|
||||
"Pretoria" => "Africa/Johannesburg",
|
||||
"Moscow" => "Europe/Moscow",
|
||||
"St. Petersburg" => "Europe/Moscow",
|
||||
"Volgograd" => "Europe/Moscow",
|
||||
"Kuwait" => "Asia/Kuwait",
|
||||
"Riyadh" => "Asia/Riyadh",
|
||||
"Nairobi" => "Africa/Nairobi",
|
||||
"Baghdad" => "Asia/Baghdad",
|
||||
"Tehran" => "Asia/Tehran",
|
||||
"Abu Dhabi" => "Asia/Muscat",
|
||||
"Muscat" => "Asia/Muscat",
|
||||
"Baku" => "Asia/Baku",
|
||||
"Tbilisi" => "Asia/Tbilisi",
|
||||
"Yerevan" => "Asia/Yerevan",
|
||||
"Kabul" => "Asia/Kabul",
|
||||
"Ekaterinburg" => "Asia/Yekaterinburg",
|
||||
"Islamabad" => "Asia/Karachi",
|
||||
"Karachi" => "Asia/Karachi",
|
||||
"Tashkent" => "Asia/Tashkent",
|
||||
"Chennai" => "Asia/Kolkata",
|
||||
"Kolkata" => "Asia/Kolkata",
|
||||
"Mumbai" => "Asia/Kolkata",
|
||||
"New Delhi" => "Asia/Kolkata",
|
||||
"Kathmandu" => "Asia/Katmandu",
|
||||
"Astana" => "Asia/Dhaka",
|
||||
"Dhaka" => "Asia/Dhaka",
|
||||
"Sri Jayawardenepura" => "Asia/Dhaka",
|
||||
"Almaty" => "Asia/Almaty",
|
||||
"Novosibirsk" => "Asia/Novosibirsk",
|
||||
"Rangoon" => "Asia/Rangoon",
|
||||
"Bangkok" => "Asia/Bangkok",
|
||||
"Hanoi" => "Asia/Bangkok",
|
||||
"Jakarta" => "Asia/Jakarta",
|
||||
"Krasnoyarsk" => "Asia/Krasnoyarsk",
|
||||
"Beijing" => "Asia/Shanghai",
|
||||
"Chongqing" => "Asia/Chongqing",
|
||||
"Hong Kong" => "Asia/Hong_Kong",
|
||||
"Urumqi" => "Asia/Urumqi",
|
||||
"Kuala Lumpur" => "Asia/Kuala_Lumpur",
|
||||
"Singapore" => "Asia/Singapore",
|
||||
"Taipei" => "Asia/Taipei",
|
||||
"Perth" => "Australia/Perth",
|
||||
"Irkutsk" => "Asia/Irkutsk",
|
||||
"Ulaan Bataar" => "Asia/Ulaanbaatar",
|
||||
"Seoul" => "Asia/Seoul",
|
||||
"Osaka" => "Asia/Tokyo",
|
||||
"Sapporo" => "Asia/Tokyo",
|
||||
"Tokyo" => "Asia/Tokyo",
|
||||
"Yakutsk" => "Asia/Yakutsk",
|
||||
"Darwin" => "Australia/Darwin",
|
||||
"Adelaide" => "Australia/Adelaide",
|
||||
"Canberra" => "Australia/Melbourne",
|
||||
"Melbourne" => "Australia/Melbourne",
|
||||
"Sydney" => "Australia/Sydney",
|
||||
"Brisbane" => "Australia/Brisbane",
|
||||
"Hobart" => "Australia/Hobart",
|
||||
"Vladivostok" => "Asia/Vladivostok",
|
||||
"Guam" => "Pacific/Guam",
|
||||
"Port Moresby" => "Pacific/Port_Moresby",
|
||||
"Magadan" => "Asia/Magadan",
|
||||
"Solomon Is." => "Asia/Magadan",
|
||||
"New Caledonia" => "Pacific/Noumea",
|
||||
"Fiji" => "Pacific/Fiji",
|
||||
"Kamchatka" => "Asia/Kamchatka",
|
||||
"Marshall Is." => "Pacific/Majuro",
|
||||
"Auckland" => "Pacific/Auckland",
|
||||
"Wellington" => "Pacific/Auckland",
|
||||
"Nuku'alofa" => "Pacific/Tongatapu"
|
||||
}.each { |name, zone| name.freeze; zone.freeze }
|
||||
MAPPING.freeze
|
||||
end
|
||||
|
||||
include Comparable
|
||||
attr_reader :name
|
||||
@@ -157,7 +160,7 @@ class TimeZone
|
||||
@utc_offset = utc_offset
|
||||
@tzinfo = tzinfo
|
||||
end
|
||||
|
||||
|
||||
def utc_offset
|
||||
@utc_offset ||= tzinfo.current_period.utc_offset
|
||||
end
|
||||
@@ -180,7 +183,7 @@ class TimeZone
|
||||
def to_s
|
||||
"(UTC#{formatted_offset}) #{name}"
|
||||
end
|
||||
|
||||
|
||||
# Method for creating new ActiveSupport::TimeWithZone instance in time zone of +self+ from given values. Example:
|
||||
#
|
||||
# Time.zone = "Hawaii" # => "Hawaii"
|
||||
@@ -199,7 +202,7 @@ class TimeZone
|
||||
utc = Time.at(secs).utc rescue DateTime.civil(1970).since(secs)
|
||||
utc.in_time_zone(self)
|
||||
end
|
||||
|
||||
|
||||
# Method for creating new ActiveSupport::TimeWithZone instance in time zone of +self+ from parsed string. Example:
|
||||
#
|
||||
# Time.zone = "Hawaii" # => "Hawaii"
|
||||
@@ -213,7 +216,7 @@ class TimeZone
|
||||
time = Time.parse(str, now) rescue DateTime.parse(str)
|
||||
ActiveSupport::TimeWithZone.new(nil, self, time)
|
||||
end
|
||||
|
||||
|
||||
# Returns an ActiveSupport::TimeWithZone instance representing the current time
|
||||
# in the time zone represented by +self+. Example:
|
||||
#
|
||||
@@ -228,12 +231,12 @@ class TimeZone
|
||||
tzinfo.now.to_date
|
||||
end
|
||||
|
||||
# Adjust the given time to the simultaneous time in the time zone represented by +self+. Returns a
|
||||
# Adjust the given time to the simultaneous time in the time zone represented by +self+. Returns a
|
||||
# Time.utc() instance -- if you want an ActiveSupport::TimeWithZone instance, use Time#in_time_zone() instead.
|
||||
def utc_to_local(time)
|
||||
tzinfo.utc_to_local(time)
|
||||
end
|
||||
|
||||
|
||||
# Adjust the given time to the simultaneous time in UTC. Returns a Time.utc() instance.
|
||||
def local_to_utc(time, dst=true)
|
||||
tzinfo.local_to_utc(time, dst)
|
||||
@@ -248,12 +251,75 @@ class TimeZone
|
||||
def period_for_local(time, dst=true)
|
||||
tzinfo.period_for_local(time, dst)
|
||||
end
|
||||
|
||||
|
||||
# TODO: Preload instead of lazy load for thread safety
|
||||
def tzinfo
|
||||
@tzinfo ||= TZInfo::Timezone.get(MAPPING[name])
|
||||
end
|
||||
|
||||
@@zones = nil
|
||||
unless const_defined?(:ZONES)
|
||||
ZONES = []
|
||||
ZONES_MAP = {}
|
||||
[[-39_600, "International Date Line West", "Midway Island", "Samoa" ],
|
||||
[-36_000, "Hawaii" ],
|
||||
[-32_400, "Alaska" ],
|
||||
[-28_800, "Pacific Time (US & Canada)", "Tijuana" ],
|
||||
[-25_200, "Mountain Time (US & Canada)", "Chihuahua", "Mazatlan",
|
||||
"Arizona" ],
|
||||
[-21_600, "Central Time (US & Canada)", "Saskatchewan", "Guadalajara",
|
||||
"Mexico City", "Monterrey", "Central America" ],
|
||||
[-18_000, "Eastern Time (US & Canada)", "Indiana (East)", "Bogota",
|
||||
"Lima", "Quito" ],
|
||||
[-14_400, "Atlantic Time (Canada)", "Caracas", "La Paz", "Santiago" ],
|
||||
[-12_600, "Newfoundland" ],
|
||||
[-10_800, "Brasilia", "Buenos Aires", "Georgetown", "Greenland" ],
|
||||
[ -7_200, "Mid-Atlantic" ],
|
||||
[ -3_600, "Azores", "Cape Verde Is." ],
|
||||
[ 0, "Dublin", "Edinburgh", "Lisbon", "London", "Casablanca",
|
||||
"Monrovia", "UTC" ],
|
||||
[ 3_600, "Belgrade", "Bratislava", "Budapest", "Ljubljana", "Prague",
|
||||
"Sarajevo", "Skopje", "Warsaw", "Zagreb", "Brussels",
|
||||
"Copenhagen", "Madrid", "Paris", "Amsterdam", "Berlin",
|
||||
"Bern", "Rome", "Stockholm", "Vienna",
|
||||
"West Central Africa" ],
|
||||
[ 7_200, "Bucharest", "Cairo", "Helsinki", "Kyev", "Riga", "Sofia",
|
||||
"Tallinn", "Vilnius", "Athens", "Istanbul", "Minsk",
|
||||
"Jerusalem", "Harare", "Pretoria" ],
|
||||
[ 10_800, "Moscow", "St. Petersburg", "Volgograd", "Kuwait", "Riyadh",
|
||||
"Nairobi", "Baghdad" ],
|
||||
[ 12_600, "Tehran" ],
|
||||
[ 14_400, "Abu Dhabi", "Muscat", "Baku", "Tbilisi", "Yerevan" ],
|
||||
[ 16_200, "Kabul" ],
|
||||
[ 18_000, "Ekaterinburg", "Islamabad", "Karachi", "Tashkent" ],
|
||||
[ 19_800, "Chennai", "Kolkata", "Mumbai", "New Delhi" ],
|
||||
[ 20_700, "Kathmandu" ],
|
||||
[ 21_600, "Astana", "Dhaka", "Sri Jayawardenepura", "Almaty",
|
||||
"Novosibirsk" ],
|
||||
[ 23_400, "Rangoon" ],
|
||||
[ 25_200, "Bangkok", "Hanoi", "Jakarta", "Krasnoyarsk" ],
|
||||
[ 28_800, "Beijing", "Chongqing", "Hong Kong", "Urumqi",
|
||||
"Kuala Lumpur", "Singapore", "Taipei", "Perth", "Irkutsk",
|
||||
"Ulaan Bataar" ],
|
||||
[ 32_400, "Seoul", "Osaka", "Sapporo", "Tokyo", "Yakutsk" ],
|
||||
[ 34_200, "Darwin", "Adelaide" ],
|
||||
[ 36_000, "Canberra", "Melbourne", "Sydney", "Brisbane", "Hobart",
|
||||
"Vladivostok", "Guam", "Port Moresby" ],
|
||||
[ 39_600, "Magadan", "Solomon Is.", "New Caledonia" ],
|
||||
[ 43_200, "Fiji", "Kamchatka", "Marshall Is.", "Auckland",
|
||||
"Wellington" ],
|
||||
[ 46_800, "Nuku'alofa" ]].
|
||||
each do |offset, *places|
|
||||
places.each do |place|
|
||||
place.freeze
|
||||
zone = new(place, offset)
|
||||
ZONES << zone
|
||||
ZONES_MAP[place] = zone
|
||||
end
|
||||
end
|
||||
ZONES.sort!
|
||||
ZONES.freeze
|
||||
ZONES_MAP.freeze
|
||||
end
|
||||
|
||||
class << self
|
||||
alias_method :create, :new
|
||||
@@ -269,67 +335,7 @@ class TimeZone
|
||||
# TimeZone objects per time zone, in many cases, to make it easier
|
||||
# for users to find their own time zone.
|
||||
def all
|
||||
unless @@zones
|
||||
@@zones = []
|
||||
@@zones_map = {}
|
||||
[[-39_600, "International Date Line West", "Midway Island", "Samoa" ],
|
||||
[-36_000, "Hawaii" ],
|
||||
[-32_400, "Alaska" ],
|
||||
[-28_800, "Pacific Time (US & Canada)", "Tijuana" ],
|
||||
[-25_200, "Mountain Time (US & Canada)", "Chihuahua", "Mazatlan",
|
||||
"Arizona" ],
|
||||
[-21_600, "Central Time (US & Canada)", "Saskatchewan", "Guadalajara",
|
||||
"Mexico City", "Monterrey", "Central America" ],
|
||||
[-18_000, "Eastern Time (US & Canada)", "Indiana (East)", "Bogota",
|
||||
"Lima", "Quito" ],
|
||||
[-14_400, "Atlantic Time (Canada)", "Caracas", "La Paz", "Santiago" ],
|
||||
[-12_600, "Newfoundland" ],
|
||||
[-10_800, "Brasilia", "Buenos Aires", "Georgetown", "Greenland" ],
|
||||
[ -7_200, "Mid-Atlantic" ],
|
||||
[ -3_600, "Azores", "Cape Verde Is." ],
|
||||
[ 0, "Dublin", "Edinburgh", "Lisbon", "London", "Casablanca",
|
||||
"Monrovia", "UTC" ],
|
||||
[ 3_600, "Belgrade", "Bratislava", "Budapest", "Ljubljana", "Prague",
|
||||
"Sarajevo", "Skopje", "Warsaw", "Zagreb", "Brussels",
|
||||
"Copenhagen", "Madrid", "Paris", "Amsterdam", "Berlin",
|
||||
"Bern", "Rome", "Stockholm", "Vienna",
|
||||
"West Central Africa" ],
|
||||
[ 7_200, "Bucharest", "Cairo", "Helsinki", "Kyev", "Riga", "Sofia",
|
||||
"Tallinn", "Vilnius", "Athens", "Istanbul", "Minsk",
|
||||
"Jerusalem", "Harare", "Pretoria" ],
|
||||
[ 10_800, "Moscow", "St. Petersburg", "Volgograd", "Kuwait", "Riyadh",
|
||||
"Nairobi", "Baghdad" ],
|
||||
[ 12_600, "Tehran" ],
|
||||
[ 14_400, "Abu Dhabi", "Muscat", "Baku", "Tbilisi", "Yerevan" ],
|
||||
[ 16_200, "Kabul" ],
|
||||
[ 18_000, "Ekaterinburg", "Islamabad", "Karachi", "Tashkent" ],
|
||||
[ 19_800, "Chennai", "Kolkata", "Mumbai", "New Delhi" ],
|
||||
[ 20_700, "Kathmandu" ],
|
||||
[ 21_600, "Astana", "Dhaka", "Sri Jayawardenepura", "Almaty",
|
||||
"Novosibirsk" ],
|
||||
[ 23_400, "Rangoon" ],
|
||||
[ 25_200, "Bangkok", "Hanoi", "Jakarta", "Krasnoyarsk" ],
|
||||
[ 28_800, "Beijing", "Chongqing", "Hong Kong", "Urumqi",
|
||||
"Kuala Lumpur", "Singapore", "Taipei", "Perth", "Irkutsk",
|
||||
"Ulaan Bataar" ],
|
||||
[ 32_400, "Seoul", "Osaka", "Sapporo", "Tokyo", "Yakutsk" ],
|
||||
[ 34_200, "Darwin", "Adelaide" ],
|
||||
[ 36_000, "Canberra", "Melbourne", "Sydney", "Brisbane", "Hobart",
|
||||
"Vladivostok", "Guam", "Port Moresby" ],
|
||||
[ 39_600, "Magadan", "Solomon Is.", "New Caledonia" ],
|
||||
[ 43_200, "Fiji", "Kamchatka", "Marshall Is.", "Auckland",
|
||||
"Wellington" ],
|
||||
[ 46_800, "Nuku'alofa" ]].
|
||||
each do |offset, *places|
|
||||
places.each do |place|
|
||||
zone = create(place, offset)
|
||||
@@zones << zone
|
||||
@@zones_map[place] = zone
|
||||
end
|
||||
end
|
||||
@@zones.sort!
|
||||
end
|
||||
@@zones
|
||||
ZONES
|
||||
end
|
||||
|
||||
# Locate a specific time zone object. If the argument is a string, it
|
||||
@@ -340,8 +346,7 @@ class TimeZone
|
||||
def [](arg)
|
||||
case arg
|
||||
when String
|
||||
all # force the zones to be loaded
|
||||
@@zones_map[arg]
|
||||
ZONES_MAP[arg]
|
||||
when Numeric, ActiveSupport::Duration
|
||||
arg *= 3600 if arg.abs <= 13
|
||||
all.find { |z| z.utc_offset == arg.to_i }
|
||||
@@ -352,7 +357,7 @@ class TimeZone
|
||||
|
||||
# A regular expression that matches the names of all time zones in
|
||||
# the USA.
|
||||
US_ZONES = /US|Arizona|Indiana|Hawaii|Alaska/
|
||||
US_ZONES = /US|Arizona|Indiana|Hawaii|Alaska/.freeze
|
||||
|
||||
# A convenience method for returning a collection of TimeZone objects
|
||||
# for time zones in the USA.
|
||||
|
||||
@@ -28,12 +28,12 @@ class NilClass
|
||||
WHINERS = [::Array]
|
||||
WHINERS << ::ActiveRecord::Base if defined? ::ActiveRecord
|
||||
|
||||
@@method_class_map = Hash.new
|
||||
METHOD_CLASS_MAP = Hash.new
|
||||
|
||||
WHINERS.each do |klass|
|
||||
methods = klass.public_instance_methods - public_instance_methods
|
||||
class_name = klass.name
|
||||
methods.each { |method| @@method_class_map[method.to_sym] = class_name }
|
||||
methods.each { |method| METHOD_CLASS_MAP[method.to_sym] = class_name }
|
||||
end
|
||||
|
||||
# Raises a RuntimeError when you attempt to call +id+ on +nil+.
|
||||
@@ -43,7 +43,7 @@ class NilClass
|
||||
|
||||
private
|
||||
def method_missing(method, *args, &block)
|
||||
raise_nil_warning_for @@method_class_map[method], method, caller
|
||||
raise_nil_warning_for METHOD_CLASS_MAP[method], method, caller
|
||||
end
|
||||
|
||||
# Raises a NoMethodError when you attempt to call a method on +nil+.
|
||||
|
||||
@@ -29,6 +29,19 @@ class OrderedHashTest < Test::Unit::TestCase
|
||||
assert_equal value, @ordered_hash.values.last
|
||||
assert_equal value, @ordered_hash[key]
|
||||
end
|
||||
|
||||
def test_delete
|
||||
key, value = 'white', 'ffffff'
|
||||
bad_key = 'black'
|
||||
|
||||
@ordered_hash[key] = value
|
||||
assert_equal @keys.length + 1, @ordered_hash.length
|
||||
|
||||
assert_equal value, @ordered_hash.delete(key)
|
||||
assert_equal @keys.length, @ordered_hash.length
|
||||
|
||||
assert_nil @ordered_hash.delete(bad_key)
|
||||
end
|
||||
end
|
||||
|
||||
class OrderedOptionsTest < Test::Unit::TestCase
|
||||
|
||||
@@ -1,5 +1,7 @@
|
||||
*SVN*
|
||||
|
||||
* Fix bug where plugin init.rb files from frozen gem specs weren't being run. (pjb3) [#122 state:resolved]
|
||||
|
||||
* Made the location of the routes file configurable with config.routes_configuration_file (Scott Fleckenstein) [#88]
|
||||
|
||||
* Rails Edge info returns the latest git commit hash [Francesc Esplugas]
|
||||
|
||||
@@ -78,7 +78,8 @@ module Rails
|
||||
# a <tt>rails/init.rb</tt> file.
|
||||
class GemLocator < Locator
|
||||
def plugins
|
||||
specs = Gem.loaded_specs.values.select do |spec|
|
||||
specs = initializer.configuration.gems.map(&:specification)
|
||||
specs + Gem.loaded_specs.values.select do |spec|
|
||||
spec.loaded_from && # prune stubs
|
||||
File.exist?(File.join(spec.full_gem_path, "rails", "init.rb"))
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user