Sha256: 3588aa8d6f6508c8a18c1dd8f705ac15c28754f4886bb3b0b7f1dfb178cee617

Contents?: true

Size: 1.95 KB

Versions: 29

Compression:

Stored size: 1.95 KB

Contents

require 'date'
require 'active_support/core_ext/time/calculations'

class String
  # Converts a string to a Time value.
  # The +form+ can be either :utc or :local (default :local).
  #
  # The time is parsed using Time.parse method.
  # If +form+ is :local, then the time is in the system timezone.
  # If the date part is missing then the current date is used and if
  # the time part is missing then it is assumed to be 00:00:00.
  #
  #   "13-12-2012".to_time               # => 2012-12-13 00:00:00 +0100
  #   "06:12".to_time                    # => 2012-12-13 06:12:00 +0100
  #   "2012-12-13 06:12".to_time         # => 2012-12-13 06:12:00 +0100
  #   "2012-12-13T06:12".to_time         # => 2012-12-13 06:12:00 +0100
  #   "2012-12-13T06:12".to_time(:utc)   # => 2012-12-13 05:12:00 UTC
  def to_time(form = :local)
    parts = Date._parse(self, false)
    return if parts.empty?

    now = Time.now
    time = Time.new(
      parts.fetch(:year, now.year),
      parts.fetch(:mon, now.month),
      parts.fetch(:mday, now.day),
      parts.fetch(:hour, 0),
      parts.fetch(:min, 0),
      parts.fetch(:sec, 0) + parts.fetch(:sec_fraction, 0),
      parts.fetch(:offset, form == :utc ? 0 : nil)
    )

    form == :utc ? time.utc : time.getlocal
  end

  # Converts a string to a Date value.
  #
  #   "1-1-2012".to_date   #=> Sun, 01 Jan 2012
  #   "01/01/2012".to_date #=> Sun, 01 Jan 2012
  #   "2012-12-13".to_date #=> Thu, 13 Dec 2012
  #   "12/13/2012".to_date #=> ArgumentError: invalid date
  def to_date
    ::Date.parse(self, false) unless blank?
  end

  # Converts a string to a DateTime value.
  #
  #   "1-1-2012".to_datetime            #=> Sun, 01 Jan 2012 00:00:00 +0000
  #   "01/01/2012 23:59:59".to_datetime #=> Sun, 01 Jan 2012 23:59:59 +0000
  #   "2012-12-13 12:50".to_datetime    #=> Thu, 13 Dec 2012 12:50:00 +0000
  #   "12/13/2012".to_datetime          #=> ArgumentError: invalid date
  def to_datetime
    ::DateTime.parse(self, false) unless blank?
  end
end

Version data entries

29 entries across 29 versions & 2 rubygems

Version Path
activesupport-4.0.13 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.13.rc1 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.11.1 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.12 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.11 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.10 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.10.rc2 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.10.rc1 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.9 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.8 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.7 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.6 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.6.rc3 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.6.rc2 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.6.rc1 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.5 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.4 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.4.rc1 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.3 lib/active_support/core_ext/string/conversions.rb
activesupport-4.0.2 lib/active_support/core_ext/string/conversions.rb