pigeon_hole 0.0.4 → 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (69) hide show
  1. checksums.yaml +4 -4
  2. data/lib/pigeon_hole.rb +11 -12
  3. data/lib/pigeon_hole/json_date.rb +9 -20
  4. data/lib/pigeon_hole/json_symbol.rb +8 -14
  5. data/lib/pigeon_hole/json_time.rb +9 -16
  6. data/lib/pigeon_hole/typed_json.rb +68 -30
  7. data/spec/integration_spec.rb +22 -6
  8. data/spec/spec_helper.rb +2 -16
  9. metadata +4 -75
  10. data/lib/pigeon_hole/json_date_time.rb +0 -28
  11. data/lib/pigeon_hole/monster-vim-2016-07-25-16-44-46.rb +0 -29
  12. data/lib/pigeon_hole/monster-vim-2016-07-25-16-44-47.rb +0 -29
  13. data/lib/pigeon_hole/monster-vim-2016-07-25-16-44-58.rb +0 -41
  14. data/lib/pigeon_hole/monster-vim-2016-07-25-16-47-02.rb +0 -41
  15. data/lib/pigeon_hole/monster-vim-2016-07-25-16-47-08.rb +0 -41
  16. data/lib/pigeon_hole/monster-vim-2016-07-25-16-47-09.rb +0 -41
  17. data/lib/pigeon_hole/monster-vim-2016-07-25-16-47-10.rb +0 -41
  18. data/lib/pigeon_hole/monster-vim-2016-07-25-16-47-35.rb +0 -29
  19. data/lib/pigeon_hole/monster-vim-2016-07-25-16-47-36.rb +0 -29
  20. data/lib/pigeon_hole/monster-vim-2016-07-25-16-47-37.rb +0 -29
  21. data/lib/pigeon_hole/monster-vim-2016-07-25-16-47-38.rb +0 -29
  22. data/lib/pigeon_hole/monster-vim-2016-07-26-10-09-11.rb +0 -41
  23. data/lib/pigeon_hole/monster-vim-2016-07-26-10-09-41.rb +0 -34
  24. data/lib/pigeon_hole/monster-vim-2016-07-26-10-09-42.rb +0 -34
  25. data/lib/pigeon_hole/monster-vim-2016-07-26-10-11-26.rb +0 -35
  26. data/lib/pigeon_hole/monster-vim-2016-07-26-10-15-33.rb +0 -39
  27. data/lib/pigeon_hole/monster-vim-2016-07-26-10-15-46.rb +0 -40
  28. data/lib/pigeon_hole/monster-vim-2016-07-26-10-15-57.rb +0 -37
  29. data/lib/pigeon_hole/monster-vim-2016-07-26-10-16-03.rb +0 -27
  30. data/lib/pigeon_hole/monster-vim-2016-07-26-10-16-04.rb +0 -27
  31. data/lib/pigeon_hole/monster-vim-2016-07-26-10-16-05.rb +0 -27
  32. data/lib/pigeon_hole/monster-vim-2016-07-26-10-17-22.rb +0 -28
  33. data/lib/pigeon_hole/monster-vim-2016-07-26-10-17-23.rb +0 -28
  34. data/lib/pigeon_hole/monster-vim-2016-07-26-10-19-14.rb +0 -28
  35. data/lib/pigeon_hole/monster-vim-2016-07-26-10-20-50.rb +0 -28
  36. data/lib/pigeon_hole/monster-vim-2016-07-26-10-20-52.rb +0 -28
  37. data/lib/pigeon_hole/monster-vim-2016-07-26-10-20-53.rb +0 -28
  38. data/lib/pigeon_hole/monster-vim-2016-07-26-10-26-57.rb +0 -42
  39. data/lib/pigeon_hole/monster-vim-2016-07-26-10-26-58.rb +0 -42
  40. data/lib/pigeon_hole/monster-vim-2016-07-26-10-27-58.rb +0 -42
  41. data/lib/pigeon_hole/monster-vim-2016-07-26-10-27-59.rb +0 -42
  42. data/lib/pigeon_hole/monster-vim-2016-07-26-10-33-40.rb +0 -42
  43. data/lib/pigeon_hole/monster-vim-2016-07-26-10-33-41.rb +0 -42
  44. data/lib/pigeon_hole/monster-vim-2016-07-26-10-33-42.rb +0 -42
  45. data/lib/pigeon_hole/monster-vim-2016-07-26-10-33-53.rb +0 -42
  46. data/lib/pigeon_hole/monster-vim-2016-07-26-10-37-07.rb +0 -42
  47. data/lib/pigeon_hole/monster-vim-2016-07-26-10-37-08.rb +0 -42
  48. data/lib/pigeon_hole/monster-vim-2016-07-26-10-37-09.rb +0 -42
  49. data/lib/pigeon_hole/monster-vim-2016-07-26-10-37-20.rb +0 -44
  50. data/lib/pigeon_hole/monster-vim-2016-07-26-10-37-21.rb +0 -44
  51. data/lib/pigeon_hole/monster-vim-2016-07-26-10-37-22.rb +0 -44
  52. data/lib/pigeon_hole/monster-vim-2016-07-26-10-37-23.rb +0 -44
  53. data/lib/pigeon_hole/monster-vim-2016-07-26-10-37-24.rb +0 -44
  54. data/lib/pigeon_hole/monster-vim-2016-07-26-10-37-25.rb +0 -44
  55. data/lib/pigeon_hole/monster-vim-2016-07-26-10-38-26.rb +0 -53
  56. data/lib/pigeon_hole/monster-vim-2016-07-26-10-38-27.rb +0 -53
  57. data/lib/pigeon_hole/monster-vim-2016-07-26-10-38-28.rb +0 -53
  58. data/lib/pigeon_hole/monster-vim-2016-07-26-10-38-29.rb +0 -53
  59. data/lib/pigeon_hole/monster-vim-2016-07-26-10-39-14.rb +0 -53
  60. data/spec/monster-vim-2016-07-26-10-29-02.rb +0 -117
  61. data/spec/monster-vim-2016-07-26-10-29-53.rb +0 -118
  62. data/spec/monster-vim-2016-07-26-12-05-32.rb +0 -117
  63. data/spec/monster-vim-2016-07-26-12-05-33.rb +0 -117
  64. data/spec/monster-vim-2016-07-26-12-05-34.rb +0 -117
  65. data/spec/monster-vim-2016-07-26-12-05-35.rb +0 -117
  66. data/spec/monster-vim-2016-07-26-12-06-22.rb +0 -33
  67. data/spec/monster-vim-2016-07-26-12-06-32.rb +0 -33
  68. data/spec/monster-vim-2016-07-26-12-06-33.rb +0 -33
  69. data/spec/monster-vim-2016-07-26-12-06-34.rb +0 -33
@@ -1,34 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- args = object.valu
8
- of_a, of_b = object['of'].split('/')
9
- if of_b and of_b != '0'
10
- args << DateTime.send(:Rational, of_a.to_i, of_b.to_i)
11
- else
12
- args << of_a
13
- end
14
- args << object['sg']
15
- DateTime.civil(*args)
16
- end
17
-
18
- # Returns a hash, that will be turned into a JSON object and represent this
19
- # object.
20
- def as_json(*)
21
- {
22
- JSON.create_id => self.class.name,
23
- 'ms' => (to_f * 1000).to_i,
24
- }
25
- end
26
-
27
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
28
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
29
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
30
- def to_json(*args)
31
- as_json.to_json(*args)
32
- end
33
- end
34
- end
@@ -1,34 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- args = object.
8
- of_a, of_b = object['of'].split('/')
9
- if of_b and of_b != '0'
10
- args << DateTime.send(:Rational, of_a.to_i, of_b.to_i)
11
- else
12
- args << of_a
13
- end
14
- args << object['sg']
15
- DateTime.civil(*args)
16
- end
17
-
18
- # Returns a hash, that will be turned into a JSON object and represent this
19
- # object.
20
- def as_json(*)
21
- {
22
- JSON.create_id => self.class.name,
23
- 'ms' => (to_f * 1000).to_i,
24
- }
25
- end
26
-
27
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
28
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
29
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
30
- def to_json(*args)
31
- as_json.to_json(*args)
32
- end
33
- end
34
- end
@@ -1,35 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- ms_since_epoc = object['ms']
8
-
9
- of_a, of_b = object['of'].split('/')
10
- if of_b and of_b != '0'
11
- args << DateTime.send(:Rational, of_a.to_i, of_b.to_i)
12
- else
13
- args << of_a
14
- end
15
- args << object['sg']
16
- DateTime.civil(*args)
17
- end
18
-
19
- # Returns a hash, that will be turned into a JSON object and represent this
20
- # object.
21
- def as_json(*)
22
- {
23
- JSON.create_id => self.class.name,
24
- 'ms' => (to_f * 1000).to_i,
25
- }
26
- end
27
-
28
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
29
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
30
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
31
- def to_json(*args)
32
- as_json.to_json(*args)
33
- end
34
- end
35
- end
@@ -1,39 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- ms_since_epoc = object['ms']
8
-
9
- seconds, fragment = Int64.from_bson(buffer).divmod(1000)
10
- at(seconds, fragment * 1000).utc
11
-
12
- of_a, of_b = object['of'].split('/')
13
- if of_b and of_b != '0'
14
- args << DateTime.send(:Rational, of_a.to_i, of_b.to_i)
15
- else
16
- args << of_a
17
- end
18
- args << object['sg']
19
-
20
- DateTime.civil(*args)
21
- end
22
-
23
- # Returns a hash, that will be turned into a JSON object and represent this
24
- # object.
25
- def as_json(*)
26
- {
27
- JSON.create_id => self.class.name,
28
- 'ms' => (to_i * 1000) + (usec / 1000),
29
- }
30
- end
31
-
32
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
33
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
34
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
35
- def to_json(*args)
36
- as_json.to_json(*args)
37
- end
38
- end
39
- end
@@ -1,40 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- ms_since_epoc = object['ms']
8
-
9
- seconds, fragment = Int64.from_bson(econds, fragment = Int64.from_bson(buffer).divmod(1000)
10
- at(seconds, fragment * 1000).utc(1000)
11
- at(seconds, fragment * 1000).utc
12
-
13
- of_a, of_b = object['of'].split('/')
14
- if of_b and of_b != '0'
15
- args << DateTime.send(:Rational, of_a.to_i, of_b.to_i)
16
- else
17
- args << of_a
18
- end
19
- args << object['sg']
20
-
21
- DateTime.civil(*args)
22
- end
23
-
24
- # Returns a hash, that will be turned into a JSON object and represent this
25
- # object.
26
- def as_json(*)
27
- {
28
- JSON.create_id => self.class.name,
29
- 'ms' => (to_i * 1000) + (usec / 1000),
30
- }
31
- end
32
-
33
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
34
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
35
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
36
- def to_json(*args)
37
- as_json.to_json(*args)
38
- end
39
- end
40
- end
@@ -1,37 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- seconds, fragment = Int64.from_bson(ms_since_epoc).divmod(1000)
8
- Time.at(seconds, fragment * 1000).utc
9
-
10
- of_a, of_b = object['of'].split('/')
11
- if of_b and of_b != '0'
12
- args << DateTime.send(:Rational, of_a.to_i, of_b.to_i)
13
- else
14
- args << of_a
15
- end
16
- args << object['sg']
17
-
18
- DateTime.civil(*args)
19
- end
20
-
21
- # Returns a hash, that will be turned into a JSON object and represent this
22
- # object.
23
- def as_json(*)
24
- {
25
- JSON.create_id => self.class.name,
26
- 'ms' => (to_i * 1000) + (usec / 1000),
27
- }
28
- end
29
-
30
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
31
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
32
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
33
- def to_json(*args)
34
- as_json.to_json(*args)
35
- end
36
- end
37
- end
@@ -1,27 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- seconds, fragment = Int64.from_bson(ms_since_epoc).divmod(1000)
8
- Time.at(seconds, fragment * 1000).utc.
9
- end
10
-
11
- # Returns a hash, that will be turned into a JSON object and represent this
12
- # object.
13
- def as_json(*)
14
- {
15
- JSON.create_id => self.class.name,
16
- 'ms' => (to_i * 1000) + (usec / 1000),
17
- }
18
- end
19
-
20
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
21
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
22
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
23
- def to_json(*args)
24
- as_json.to_json(*args)
25
- end
26
- end
27
- end
@@ -1,27 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- seconds, fragment = Int64.from_bson(ms_since_epoc).divmod(1000)
8
- Time.at(seconds, fragment * 1000).utc.to
9
- end
10
-
11
- # Returns a hash, that will be turned into a JSON object and represent this
12
- # object.
13
- def as_json(*)
14
- {
15
- JSON.create_id => self.class.name,
16
- 'ms' => (to_i * 1000) + (usec / 1000),
17
- }
18
- end
19
-
20
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
21
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
22
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
23
- def to_json(*args)
24
- as_json.to_json(*args)
25
- end
26
- end
27
- end
@@ -1,27 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- seconds, fragment = Int64.from_bson(ms_since_epoc).divmod(1000)
8
- Time.at(seconds, fragment * 1000).utc.to_datetime
9
- end
10
-
11
- # Returns a hash, that will be turned into a JSON object and represent this
12
- # object.
13
- def as_json(*)
14
- {
15
- JSON.create_id => self.class.name,
16
- 'ms' => (to_i * 1000) + (usec / 1000),
17
- }
18
- end
19
-
20
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
21
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
22
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
23
- def to_json(*args)
24
- as_json.to_json(*args)
25
- end
26
- end
27
- end
@@ -1,28 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- ms_since_epoc = object['ms'].
8
- seconds, fragment = ms_since_epoc.divmod(1000)
9
- Time.at(seconds, fragment * 1000).utc.to_datetime
10
- end
11
-
12
- # Returns a hash, that will be turned into a JSON object and represent this
13
- # object.
14
- def as_json(*)
15
- {
16
- JSON.create_id => self.class.name,
17
- 'ms' => (to_i * 1000) + (usec / 1000),
18
- }
19
- end
20
-
21
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
22
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
23
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
24
- def to_json(*args)
25
- as_json.to_json(*args)
26
- end
27
- end
28
- end
@@ -1,28 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- ms_since_epoc = object['ms'].to
8
- seconds, fragment = ms_since_epoc.divmod(1000)
9
- Time.at(seconds, fragment * 1000).utc.to_datetime
10
- end
11
-
12
- # Returns a hash, that will be turned into a JSON object and represent this
13
- # object.
14
- def as_json(*)
15
- {
16
- JSON.create_id => self.class.name,
17
- 'ms' => (to_i * 1000) + (usec / 1000),
18
- }
19
- end
20
-
21
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
22
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
23
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
24
- def to_json(*args)
25
- as_json.to_json(*args)
26
- end
27
- end
28
- end
@@ -1,28 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- ms_since_epoc = object['ms'].to_i
8
- seconds, fragment = ms_since_epoc.divmod(1000)
9
- Time.at(seconds, fragment * 1000).utc.to_datetime
10
- end
11
-
12
- # Returns a hash, that will be turned into a JSON object and represent this
13
- # object.
14
- def as_json(*)
15
- {
16
- JSON.create_id => self.class.name,
17
- 'ms' => (to_i * 1000) + (to_time.usec / 1000),
18
- }
19
- end
20
-
21
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
22
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
23
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
24
- def to_json(*args)
25
- as_json.to_json(*args)
26
- end
27
- end
28
- end
@@ -1,28 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- ms_since_epoc = object['ms'].to_i
8
- seconds, fragment = ms_since_epoc.divmod(1000)
9
- Time.at(seconds, fragment * 1000).utc.to_datetime
10
- end
11
-
12
- # Returns a hash, that will be turned into a JSON object and represent this
13
- # object.
14
- def as_json(*)
15
- {
16
- JSON.create_id => self.class.name,
17
- 'ms' => (to_time.to_i * 1000) + (to_time.usec / 1000),
18
- }
19
- end
20
-
21
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
22
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
23
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
24
- def to_json(*args)
25
- as_json.to_json(*args)
26
- end
27
- end
28
- end
@@ -1,28 +0,0 @@
1
- module PigeonHole
2
- class JSONDateTime < SimpleDelegator
3
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
4
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
5
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
6
- def self.json_create(object)
7
- ms_since_epoc = object['ms'].to_i
8
- seconds, fragment = ms_since_epoc.divmod(1000)
9
- Time.at(seconds, fragment * 1000).utc.to_datetime
10
- end
11
-
12
- # Returns a hash, that will be turned into a JSON object and represent this
13
- # object.
14
- def as_json(*)
15
- {
16
- JSON.create_id => self.class.name,
17
- 'ms' => (to_time.tv * 1000) + (to_time.usec / 1000),
18
- }
19
- end
20
-
21
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
22
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
23
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
24
- def to_json(*args)
25
- as_json.to_json(*args)
26
- end
27
- end
28
- end