sugarcube 0.16.2 → 0.16.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/README.md +7 -0
- data/lib/sugarcube/activesupport.rb +28 -0
- data/lib/sugarcube/fixnum.rb +4 -0
- data/lib/sugarcube/numeric.rb +36 -0
- data/lib/sugarcube/uicolor.rb +10 -4
- data/lib/sugarcube/version.rb +1 -1
- data/spec/activesupport_spec.rb +79 -0
- data/spec/fixnum_spec.rb +1 -0
- data/spec/nsurl_spec.rb +11 -0
- data/spec/numeric_spec.rb +36 -0
- data/spec/{symbol_uicolor_spec.rb → uicolor_css_spec.rb} +2 -1
- data/spec/uicolor_spec.rb +11 -0
- data/spec/uiimage_scale_spec.rb +9 -1
- metadata +11 -5
- data/lib/sugarcube/ror.rb +0 -13
data/README.md
CHANGED
@@ -1320,6 +1320,8 @@ Quick wrapper for `CFUUIDCreate()` and `CFUUIDCreateString()`. Identical to the
|
|
1320
1320
|
Ruby on Rails Ripoffs (RoR-R?)
|
1321
1321
|
---------------
|
1322
1322
|
|
1323
|
+
aka `ActiveSupport`.
|
1324
|
+
|
1323
1325
|
```ruby
|
1324
1326
|
# truthiness with `blank?`
|
1325
1327
|
nil.blank? # => true
|
@@ -1333,6 +1335,11 @@ true.blank? # => false
|
|
1333
1335
|
'a'.blank? # => false
|
1334
1336
|
['a'].blank? # => false
|
1335
1337
|
{a: 'a'}.blank? # => false
|
1338
|
+
|
1339
|
+
# and my favorite
|
1340
|
+
1.in? [1,2,3] # => true
|
1341
|
+
1.in? 1,2,3 # => true
|
1342
|
+
1.in? 4..5 # => false
|
1336
1343
|
```
|
1337
1344
|
|
1338
1345
|
Gestures
|
@@ -0,0 +1,28 @@
|
|
1
|
+
# Thanks ruby on rails!
|
2
|
+
#
|
3
|
+
# These are all blatent, unapologetic rip offs of RoR extensions, and they
|
4
|
+
# behave in exactly the same way.
|
5
|
+
|
6
|
+
class Object
|
7
|
+
|
8
|
+
def blank?
|
9
|
+
respond_to?(:empty?) ? empty? : !self
|
10
|
+
end
|
11
|
+
|
12
|
+
def present?
|
13
|
+
!blank?
|
14
|
+
end
|
15
|
+
|
16
|
+
# okay, this is strange, but `rake spec` fails if I define the method as `in?`
|
17
|
+
# but passes if I alias it, as I do below. weird, but I don't want to fight
|
18
|
+
# it.
|
19
|
+
def in(*list)
|
20
|
+
if list.length == 1
|
21
|
+
return list[0].include?(self)
|
22
|
+
else
|
23
|
+
return list.include?(self)
|
24
|
+
end
|
25
|
+
end
|
26
|
+
alias :in? :in
|
27
|
+
|
28
|
+
end
|
data/lib/sugarcube/fixnum.rb
CHANGED
data/lib/sugarcube/numeric.rb
CHANGED
@@ -54,6 +54,42 @@ class Numeric
|
|
54
54
|
self / 1.foot
|
55
55
|
end
|
56
56
|
|
57
|
+
def bytes
|
58
|
+
self
|
59
|
+
end
|
60
|
+
alias byte bytes
|
61
|
+
|
62
|
+
def kilobytes
|
63
|
+
self * 1024**1
|
64
|
+
end
|
65
|
+
alias kilobyte kilobytes
|
66
|
+
|
67
|
+
def megabytes
|
68
|
+
self * 1024**2
|
69
|
+
end
|
70
|
+
alias megabyte megabytes
|
71
|
+
|
72
|
+
def gigabytes
|
73
|
+
self * 1024**3
|
74
|
+
end
|
75
|
+
alias gigabyte gigabytes
|
76
|
+
|
77
|
+
def terabytes
|
78
|
+
self * 1024**4
|
79
|
+
end
|
80
|
+
alias terabyte terabytes
|
81
|
+
|
82
|
+
def petabytes
|
83
|
+
self * 1024**5
|
84
|
+
end
|
85
|
+
alias petabyte petabytes
|
86
|
+
|
87
|
+
def exabytes
|
88
|
+
self * 1024**6
|
89
|
+
end
|
90
|
+
alias exabyte exabytes
|
91
|
+
|
92
|
+
|
57
93
|
def string_with_style(style=NSNumberFormatterDecimalStyle)
|
58
94
|
if style.is_a? Symbol
|
59
95
|
style = style.nsnumberstyle
|
data/lib/sugarcube/uicolor.rb
CHANGED
@@ -1,14 +1,20 @@
|
|
1
1
|
class UIColor
|
2
|
-
def uicolor
|
3
|
-
|
4
|
-
|
5
|
-
|
2
|
+
def uicolor(alpha=nil)
|
3
|
+
if alpha
|
4
|
+
self.colorWithAlphaComponent(alpha.to_f)
|
5
|
+
else
|
6
|
+
self
|
7
|
+
end
|
6
8
|
end
|
7
9
|
|
8
10
|
def cgcolor
|
9
11
|
self.CGColor
|
10
12
|
end
|
11
13
|
|
14
|
+
def red
|
15
|
+
_sugarcube_colors && _sugarcube_colors[:red]
|
16
|
+
end
|
17
|
+
|
12
18
|
def green
|
13
19
|
_sugarcube_colors && _sugarcube_colors[:green]
|
14
20
|
end
|
data/lib/sugarcube/version.rb
CHANGED
@@ -0,0 +1,79 @@
|
|
1
|
+
describe 'ActiveSupport' do
|
2
|
+
|
3
|
+
describe "should have a blank? method" do
|
4
|
+
it "should be false for #{true.inspect}" do
|
5
|
+
true.blank?.should == false
|
6
|
+
end
|
7
|
+
it "should be false for #{false.inspect}" do
|
8
|
+
false.blank?.should == true
|
9
|
+
end
|
10
|
+
it "should be false for #{[].inspect}" do
|
11
|
+
[].blank?.should == true
|
12
|
+
end
|
13
|
+
it "should be false for #{[1].inspect}" do
|
14
|
+
[1].blank?.should == false
|
15
|
+
end
|
16
|
+
it "should be false for #{{}.inspect}" do
|
17
|
+
{}.blank?.should == true
|
18
|
+
end
|
19
|
+
it "should be false for #{{a:1}.inspect}" do
|
20
|
+
{a:1}.blank?.should == false
|
21
|
+
end
|
22
|
+
it "should be false for #{''.inspect}" do
|
23
|
+
''.blank?.should == true
|
24
|
+
end
|
25
|
+
it "should be false for #{'a'.inspect}" do
|
26
|
+
'a'.blank?.should == false
|
27
|
+
end
|
28
|
+
it "should be false for #{' '.inspect}" do
|
29
|
+
' '.blank?.should == false
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
describe "should have a present? method" do
|
34
|
+
it "should be false for #{true.inspect}" do
|
35
|
+
true.present?.should == true
|
36
|
+
end
|
37
|
+
it "should be false for #{false.inspect}" do
|
38
|
+
false.present?.should == false
|
39
|
+
end
|
40
|
+
it "should be false for #{[].inspect}" do
|
41
|
+
[].present?.should == false
|
42
|
+
end
|
43
|
+
it "should be false for #{[1].inspect}" do
|
44
|
+
[1].present?.should == true
|
45
|
+
end
|
46
|
+
it "should be false for #{{}.inspect}" do
|
47
|
+
{}.present?.should == false
|
48
|
+
end
|
49
|
+
it "should be false for #{{a:1}.inspect}" do
|
50
|
+
{a:1}.present?.should == true
|
51
|
+
end
|
52
|
+
it "should be false for #{''.inspect}" do
|
53
|
+
''.present?.should == false
|
54
|
+
end
|
55
|
+
it "should be false for #{'a'.inspect}" do
|
56
|
+
'a'.present?.should == true
|
57
|
+
end
|
58
|
+
it "should be false for #{' '.inspect}" do
|
59
|
+
' '.present?.should == true
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
it "should have an in? method" do
|
64
|
+
1.in?(1,2,3).should == true
|
65
|
+
0.in?(1,2,3).should == false
|
66
|
+
|
67
|
+
1.in?([1,2,3]).should == true
|
68
|
+
0.in?([1,2,3]).should == false
|
69
|
+
|
70
|
+
:a.in?({a:1,b:2,c:3}).should == true
|
71
|
+
1.in?({a:1,b:2,c:3}).should == false
|
72
|
+
|
73
|
+
1.in?(1..3).should == true
|
74
|
+
0.in?(1..3).should == false
|
75
|
+
|
76
|
+
:anything.in?().should == false
|
77
|
+
end
|
78
|
+
|
79
|
+
end
|
data/spec/fixnum_spec.rb
CHANGED
data/spec/nsurl_spec.rb
ADDED
data/spec/numeric_spec.rb
CHANGED
@@ -74,6 +74,42 @@ describe "Numeric" do
|
|
74
74
|
2.meters.in_feet.round.should == 7
|
75
75
|
end
|
76
76
|
|
77
|
+
it "should have a #byte method" do
|
78
|
+
1.byte.should == 1
|
79
|
+
2.bytes.should == 2
|
80
|
+
end
|
81
|
+
|
82
|
+
it "should have a #kilobyte method" do
|
83
|
+
1.kilobyte.should == 1 * 1024**1
|
84
|
+
2.kilobytes.should == 2 * 1024**1
|
85
|
+
end
|
86
|
+
|
87
|
+
it "should have a #megabyte method" do
|
88
|
+
1.megabyte.should == 1 * 1024**2
|
89
|
+
2.megabytes.should == 2 * 1024**2
|
90
|
+
end
|
91
|
+
|
92
|
+
it "should have a #gigabyte method" do
|
93
|
+
1.gigabyte.should == 1 * 1024**3
|
94
|
+
2.gigabytes.should == 2 * 1024**3
|
95
|
+
end
|
96
|
+
|
97
|
+
it "should have a #terabyte method" do
|
98
|
+
1.terabyte.should == 1 * 1024**4
|
99
|
+
2.terabytes.should == 2 * 1024**4
|
100
|
+
end
|
101
|
+
|
102
|
+
it "should have a #petabyte method" do
|
103
|
+
1.petabyte.should == 1 * 1024**5
|
104
|
+
2.petabytes.should == 2 * 1024**5
|
105
|
+
end
|
106
|
+
|
107
|
+
it "should have a #exabyte method" do
|
108
|
+
1.exabyte.should == 1 * 1024**6
|
109
|
+
2.exabytes.should == 2 * 1024**6
|
110
|
+
end
|
111
|
+
|
112
|
+
|
77
113
|
it "should have a #string_with_style method" do
|
78
114
|
1000.string_with_style.should == NSNumberFormatter.localizedStringFromNumber(1000, numberStyle:NSNumberFormatterDecimalStyle)
|
79
115
|
1000.string_with_style(:decimal).should == NSNumberFormatter.localizedStringFromNumber(1000, numberStyle:NSNumberFormatterDecimalStyle)
|
@@ -1,4 +1,4 @@
|
|
1
|
-
describe '
|
1
|
+
describe 'UIColor (CSS)' do
|
2
2
|
|
3
3
|
it "should return css color names" do
|
4
4
|
except_for = [:aqua, :fuchsia, :lime]
|
@@ -6,6 +6,7 @@ describe 'Symbol#uicolor' do
|
|
6
6
|
next if except_for.include? name
|
7
7
|
|
8
8
|
color = val.uicolor
|
9
|
+
color.css_name.should == name
|
9
10
|
color.to_s.should == "UIColor.color(#{name.inspect})"
|
10
11
|
end
|
11
12
|
end
|
data/spec/uiimage_scale_spec.rb
CHANGED
@@ -40,12 +40,20 @@ describe "UIImage scale methods" do
|
|
40
40
|
|
41
41
|
it 'should scale_to_fill a wider size' do
|
42
42
|
scaled = @image.scale_to_fill([20, 10])
|
43
|
-
scaled.nsdata.writeToFile('
|
43
|
+
scaled.nsdata.writeToFile('scale_to_fill_wider.png'.document, atomically: true)
|
44
44
|
scaled.size.width.should == 20
|
45
45
|
scaled.size.height.should == 10
|
46
46
|
scaled.scale.should == @image.scale
|
47
47
|
end
|
48
48
|
|
49
|
+
it 'should scale_to_fill a smaller size' do
|
50
|
+
scaled = @image.scale_to_fill([5, 5])
|
51
|
+
scaled.nsdata.writeToFile('scale_to_fill_smaller.png'.document, atomically: true)
|
52
|
+
scaled.size.width.should == 5
|
53
|
+
scaled.size.height.should == 5
|
54
|
+
scaled.scale.should == @image.scale
|
55
|
+
end
|
56
|
+
|
49
57
|
it 'scale_to_fill should support position' do
|
50
58
|
scaled = @image.scale_to_fill([10, 20], position: :top_left)
|
51
59
|
scaled.nsdata.writeToFile('scale_to_fill_position_top_left.png'.document, atomically: true)
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sugarcube
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.16.
|
4
|
+
version: 0.16.5
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -13,7 +13,7 @@ authors:
|
|
13
13
|
autorequire:
|
14
14
|
bindir: bin
|
15
15
|
cert_chain: []
|
16
|
-
date: 2013-02-
|
16
|
+
date: 2013-02-08 00:00:00.000000000 Z
|
17
17
|
dependencies: []
|
18
18
|
description: ! '== Description
|
19
19
|
|
@@ -55,6 +55,7 @@ files:
|
|
55
55
|
- lib/sugarcube-unholy.rb
|
56
56
|
- lib/sugarcube-unholy/ivar.rb
|
57
57
|
- lib/sugarcube.rb
|
58
|
+
- lib/sugarcube/activesupport.rb
|
58
59
|
- lib/sugarcube/adjust.rb
|
59
60
|
- lib/sugarcube/calayer.rb
|
60
61
|
- lib/sugarcube/core_graphics.rb
|
@@ -76,7 +77,6 @@ files:
|
|
76
77
|
- lib/sugarcube/nsurl.rb
|
77
78
|
- lib/sugarcube/nsuserdefaults.rb
|
78
79
|
- lib/sugarcube/numeric.rb
|
79
|
-
- lib/sugarcube/ror.rb
|
80
80
|
- lib/sugarcube/symbol.rb
|
81
81
|
- lib/sugarcube/symbol/symbol_uicolor.rb
|
82
82
|
- lib/sugarcube/timer.rb
|
@@ -117,6 +117,7 @@ files:
|
|
117
117
|
- resources/tall@2x.png
|
118
118
|
- runtests
|
119
119
|
- spec/568_spec.rb
|
120
|
+
- spec/activesupport_spec.rb
|
120
121
|
- spec/calayer_spec.rb
|
121
122
|
- spec/core_graphics_spec.rb
|
122
123
|
- spec/core_location_spec.rb
|
@@ -130,9 +131,11 @@ files:
|
|
130
131
|
- spec/nsdate_upto_spec.rb
|
131
132
|
- spec/nsstring_files_spec.rb
|
132
133
|
- spec/nsstring_spec.rb
|
134
|
+
- spec/nsurl_spec.rb
|
133
135
|
- spec/numeric_spec.rb
|
134
|
-
- spec/symbol_uicolor_spec.rb
|
135
136
|
- spec/uicolor_components_spec.rb
|
137
|
+
- spec/uicolor_css_spec.rb
|
138
|
+
- spec/uicolor_spec.rb
|
136
139
|
- spec/uiimage_color_at_spec.rb
|
137
140
|
- spec/uiimage_scale_spec.rb
|
138
141
|
- spec/uiview_animation_spec.rb
|
@@ -166,6 +169,7 @@ summary: Extensions for Ruby to make Rubymotion development more enjoyable, and
|
|
166
169
|
more rubyesque!
|
167
170
|
test_files:
|
168
171
|
- spec/568_spec.rb
|
172
|
+
- spec/activesupport_spec.rb
|
169
173
|
- spec/calayer_spec.rb
|
170
174
|
- spec/core_graphics_spec.rb
|
171
175
|
- spec/core_location_spec.rb
|
@@ -179,9 +183,11 @@ test_files:
|
|
179
183
|
- spec/nsdate_upto_spec.rb
|
180
184
|
- spec/nsstring_files_spec.rb
|
181
185
|
- spec/nsstring_spec.rb
|
186
|
+
- spec/nsurl_spec.rb
|
182
187
|
- spec/numeric_spec.rb
|
183
|
-
- spec/symbol_uicolor_spec.rb
|
184
188
|
- spec/uicolor_components_spec.rb
|
189
|
+
- spec/uicolor_css_spec.rb
|
190
|
+
- spec/uicolor_spec.rb
|
185
191
|
- spec/uiimage_color_at_spec.rb
|
186
192
|
- spec/uiimage_scale_spec.rb
|
187
193
|
- spec/uiview_animation_spec.rb
|