glimmer-dsl-swt 4.20.8.0 → 4.20.10.1

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 22394bc84cfc12938603e2566009365c2d23f9eee64f49b9da159f201438ca78
4
- data.tar.gz: d00cd63f2663d46628e26a9dd974705e29d6d97e5c4b9d686194899662b34218
3
+ metadata.gz: 13187ec0b73c8a5952858310e3c42e511f2e48f4e278b58e075476781b7c5c3d
4
+ data.tar.gz: 5122305d5bac89596a966afca60fc6fd7085f0ceb6fdc4e8ac8317cdc3399667
5
5
  SHA512:
6
- metadata.gz: ab487ddda276df797b56bdc5ad201ec6a9f02abcda356d13f8bdaa7c70eb3a90252459cc83872e28e88bf0b14284eafcaf05ee1f1dfca1468b88730eb1364b74
7
- data.tar.gz: 1a8bb076d8bfb3daa0678477039c3220c5e49e206e08e641d2c701a5ef72a1ac3820a4f19539077be5d6d7ee5e65332f9118e88214b9d1cc9e6960a6c84339a9
6
+ metadata.gz: ded05c6457281d9b11ae751a6c28561fe9789a25c21abde7d30ba79c2232780deb919ab6a700d9c719a103de95fdd7e7a0941cb8b4716b6c8586baac0490aa2f
7
+ data.tar.gz: edb3e68ff37552894bf004b916351772cac70520153b97fb7683258667bb3b384659eaea1ab57f7319a7325f7adda1e6a1438c9a49cf436f16d8d965353be496
data/CHANGELOG.md CHANGED
@@ -1,5 +1,25 @@
1
1
  # Change Log
2
2
 
3
+ ### 4.20.10.1
4
+
5
+ - Hello, Scale! sample.
6
+
7
+ ### 4.20.10.0
8
+
9
+ - Support noun alternatives for `Canvas Transform DSL` operations:
10
+ - `multiply(&block)` => `multiplication(&block)`
11
+ - `invert` => `inversion`
12
+ - `rotate(angle)` => `rotation(angle)`
13
+ - `translate(x, y)` => `translation(x, y)`
14
+
15
+ ### 4.20.9.1
16
+
17
+ - Fix issue with not being able to use :default x/y location with composite/custom shapes containing lines
18
+
19
+ ### 4.20.9.0
20
+
21
+ - Canvas animation fps/frame_rate property to set frames-per-second rate of rendering (alternative to every)
22
+
3
23
  ### 4.20.8.0
4
24
 
5
25
  - Support data-binding Animation `duration_limit` property
data/README.md CHANGED
@@ -1,4 +1,4 @@
1
- # [<img src="https://raw.githubusercontent.com/AndyObtiva/glimmer/master/images/glimmer-logo-hi-res.png" height=85 />](https://github.com/AndyObtiva/glimmer) Glimmer DSL for SWT 4.20.8.0
1
+ # [<img src="https://raw.githubusercontent.com/AndyObtiva/glimmer/master/images/glimmer-logo-hi-res.png" height=85 />](https://github.com/AndyObtiva/glimmer) Glimmer DSL for SWT 4.20.10.1
2
2
  ## JRuby Desktop Development GUI Framework
3
3
  [![Gem Version](https://badge.fury.io/rb/glimmer-dsl-swt.svg)](http://badge.fury.io/rb/glimmer-dsl-swt)
4
4
  [![Travis CI](https://travis-ci.com/AndyObtiva/glimmer-dsl-swt.svg?branch=master)](https://travis-ci.com/github/AndyObtiva/glimmer-dsl-swt)
@@ -15,7 +15,7 @@
15
15
  [<img src="https://covers.oreillystatic.com/images/9780596519650/lrg.jpg" width=105 /><br />
16
16
  Featured in JRuby Cookbook](http://shop.oreilly.com/product/9780596519650.do) and [Chalmers/Gothenburg University Software Engineering Master's Lecture Material](http://www.cse.chalmers.se/~bergert/slides/guest_lecture_DSLs.pdf)
17
17
 
18
- [Glimmer DSL for SWT](https://rubygems.org/gems/glimmer-dsl-swt) 4.20.8.0 includes [SWT 4.20](https://download.eclipse.org/eclipse/downloads/drops4/R-4.20-202106111600/), which was released on June 11, 2021. Gem version numbers are in sync with the SWT library versions. The first two digits represent the SWT version number. The last two digits represent the minor and patch versions of Glimmer DSL for SWT. Note that SWT now supports AARCH64 on Mac and Linux, but it is not fully tested in Glimmer DSL for SWT yet, so deem its support experimental for the time being without guarantees for functionality until declared otherwise (report any issues you may encounter).
18
+ [Glimmer DSL for SWT](https://rubygems.org/gems/glimmer-dsl-swt) 4.20.10.1 includes [SWT 4.20](https://download.eclipse.org/eclipse/downloads/drops4/R-4.20-202106111600/), which was released on June 11, 2021. Gem version numbers are in sync with the SWT library versions. The first two digits represent the SWT version number. The last two digits represent the minor and patch versions of Glimmer DSL for SWT. Note that SWT now supports AARCH64 on Mac and Linux, but it is not fully tested in Glimmer DSL for SWT yet, so deem its support experimental for the time being without guarantees for functionality until declared otherwise (report any issues you may encounter).
19
19
 
20
20
  **Starting in version 4.20.0.0, [Glimmer DSL for SWT](https://rubygems.org/gems/glimmer-dsl-swt) comes with the new [***Shine***](/docs/reference/GLIMMER_GUI_DSL_SYNTAX.md#shine) syntax** for highly intuitive and visually expressive View/Model Attribute Mapping, relying on `<=>` for bidirectional (two-way) data-binding and `<=` for unidirectional (one-way) data-binding, providing an alternative to the `bind` keyword (keep in mind that it is still a beta, so default back to `bind` whenever needed).
21
21
 
@@ -347,7 +347,7 @@ jgem install glimmer-dsl-swt
347
347
 
348
348
  Or this command if you want a specific version:
349
349
  ```
350
- jgem install glimmer-dsl-swt -v 4.20.8.0
350
+ jgem install glimmer-dsl-swt -v 4.20.10.1
351
351
  ```
352
352
 
353
353
  `jgem` is JRuby's version of `gem` command.
@@ -375,7 +375,7 @@ Note: if you're using activerecord or activesupport, keep in mind that Glimmer u
375
375
 
376
376
  Add the following to `Gemfile`:
377
377
  ```
378
- gem 'glimmer-dsl-swt', '~> 4.20.8.0'
378
+ gem 'glimmer-dsl-swt', '~> 4.20.10.1'
379
379
  ```
380
380
 
381
381
  And, then run:
@@ -396,7 +396,7 @@ glimmer
396
396
  ```
397
397
 
398
398
  ```
399
- Glimmer (JRuby Desktop Development GUI Framework) - JRuby Gem: glimmer-dsl-swt v4.20.8.0
399
+ Glimmer (JRuby Desktop Development GUI Framework) - JRuby Gem: glimmer-dsl-swt v4.20.10.1
400
400
 
401
401
  Usage: glimmer [--bundler] [--pd] [--quiet] [--debug] [--log-level=VALUE] [[ENV_VAR=VALUE]...] [[-jruby-option]...] (application.rb or task[task_args]) [[application2.rb]...]
402
402
 
data/VERSION CHANGED
@@ -1 +1 @@
1
- 4.20.8.0
1
+ 4.20.10.1
@@ -2165,12 +2165,12 @@ The first 2 values represent the 1st row, the second 2 values represent the 2nd
2165
2165
 
2166
2166
  Additionally, Transform operation keywords may be nested within the `transform` keyword to set its properties:
2167
2167
  - `identity` resets transform to identity (no transformation)
2168
- - `invert` inverts a transform
2169
- - `multiply(&block)` multiplies by another transform (takes a block representing properties of another transform, no need for using the word transform again)
2170
- - `rotate(angle)` rotates by angle degrees
2168
+ - `invert` (alias: `inversion`) inverts a transform
2169
+ - `multiply(&transform_properties_block)` (alias: `multiplication`) multiplies by another transform (takes a block representing properties of another transform, no need for using the word transform again)
2170
+ - `rotate(angle)` (alias: `rotation`) rotates by angle degrees
2171
2171
  - `scale(x, y)` scales a shape (stretch)
2172
2172
  - `shear(x, y)` shear effect
2173
- - `translate(x, y)` translate x and y coordinates (move)
2173
+ - `translate(x, y)` (alias: `translation`) translate x and y coordinates (move)
2174
2174
  - `elements(m11, m12, m21, m22, dx, dy)` resets all values of the transform matrix (first 2 values represent the 1st row, second 2 values represent the 2nd row, the last 2 values represent translation on x and y axes)
2175
2175
 
2176
2176
  Also, setting `transform` to `nil` after a previous `transform` has been set is like calling `identity`. It resets the transform.
@@ -2239,7 +2239,7 @@ Learn more at the [Hello, Canvas Transform! Sample](GLIMMER_SAMPLES.md#hello-can
2239
2239
 
2240
2240
  ### Canvas Animation DSL
2241
2241
 
2242
- **(ALPHA FEATURE)**
2242
+ **(EXPERIMENTAL EARLY ALPHA FEATURE)**
2243
2243
 
2244
2244
  (note: this is a very new feature of Glimmer. It may change a bit while getting battle tested. As always, you could default to basic SWT usage if needed.)
2245
2245
 
@@ -2281,7 +2281,8 @@ Screenshot:
2281
2281
 
2282
2282
  Keywords:
2283
2283
  - `animation` declares an animation under a canvas, which renders frames using a frame block indefinitely or finitely depending on (cycle_count/frame_count) properties
2284
- - `every` specifies delay in seconds between every two frame renders
2284
+ - `every` specifies delay in seconds between every two frame renders (an alternative to `fps`, cannot use together)
2285
+ - `fps` (alias: `frame_rate`) specifies frame rate as frames per second (an alternative to `every`, cannot use together)
2285
2286
  - `frame {|index, cycle_var| }` a block that can contain Shape DSL syntax that is rendered dynamically with variables calculated on the fly
2286
2287
  - `cycle` an optional property that takes an array to cycle into a second variable for the `frame` block
2287
2288
  - `cycle_count` an optional cycle count limit after which the animation stops (finishes)
@@ -32,6 +32,7 @@
32
32
  - [Hello, Directory Dialog!](#hello-directory-dialog)
33
33
  - [Hello, File Dialog!](#hello-file-dialog)
34
34
  - [Hello, Date Time!](#hello-date-time)
35
+ - [Hello, Scale!](#hello-scale)
35
36
  - [Hello, Spinner!](#hello-spinner)
36
37
  - [Hello, Table!](#hello-table)
37
38
  - [Hello, Link!](#hello-link)
@@ -593,6 +594,18 @@ Hello, Date Time!
593
594
 
594
595
  ![Hello Date Time](/images/glimmer-hello-date-time.png)
595
596
 
597
+ #### Hello, Scale!
598
+
599
+ This sample demonstrates the use of `scale` widget in Glimmer
600
+
601
+ Code:
602
+
603
+ [samples/hello/hello_scale.rb](/samples/hello/hello_scale.rb)
604
+
605
+ Hello, Scale!
606
+
607
+ ![Hello Scale](/images/glimmer-hello-scale.png)
608
+
596
609
  #### Hello, Spinner!
597
610
 
598
611
  This sample demonstrates the use of `spinner` widget in Glimmer
Binary file
@@ -31,7 +31,10 @@ module Glimmer
31
31
  include ParentExpression
32
32
 
33
33
  def can_interpret?(parent, keyword, *args, &block)
34
- keyword == 'multiply' and
34
+ (
35
+ keyword == 'multiply' or
36
+ keyword == 'multiplication'
37
+ ) and
35
38
  parent.is_a?(Glimmer::SWT::TransformProxy)
36
39
  end
37
40
 
@@ -21,6 +21,7 @@
21
21
 
22
22
  require 'glimmer/swt/properties'
23
23
  require 'glimmer/swt/custom/shape'
24
+ require 'bigdecimal'
24
25
 
25
26
  module Glimmer
26
27
  module SWT
@@ -79,10 +80,12 @@ module Glimmer
79
80
  end
80
81
 
81
82
  attr_reader :parent, :options
82
- attr_accessor :frame_index, :cycle, :frame_block, :every, :cycle_count, :frame_count, :started, :duration_limit, :duration, :finished, :cycle_count_index
83
+ attr_accessor :frame_index, :cycle, :frame_block, :every, :fps, :cycle_count, :frame_count, :started, :duration_limit, :duration, :finished, :cycle_count_index
83
84
  alias current_frame_index frame_index
84
85
  alias started? started
85
86
  alias finished? finished
87
+ alias frame_rate fps
88
+ alias frame_rate= fps=
86
89
  # TODO consider supporting an async: false option
87
90
 
88
91
  def initialize(parent)
@@ -266,7 +269,12 @@ module Glimmer
266
269
  end
267
270
  self.frame_index += 1
268
271
  self.cycle_count_index += 1 if cycle_limited? && (@frame_index % @cycle&.length&.to_i) == 0
269
- sleep(every) if every.is_a?(Numeric) # TODO consider using timer_exec as a perhaps more reliable alternative
272
+ # TODO consider using timer_exec as a perhaps more reliable alternative
273
+ if every.is_a?(Numeric) && every > 0
274
+ sleep(every)
275
+ elsif fps.is_a?(Numeric) && fps > 0
276
+ sleep((BigDecimal(1.0.to_s) / BigDecimal(fps.to_f.to_s)).to_f)
277
+ end
270
278
  true
271
279
  rescue => e
272
280
  Glimmer::Config.logger.error {e}
@@ -71,14 +71,14 @@ module Glimmer
71
71
  # Logical x coordinate relative to parent
72
72
  def x
73
73
  x_value = bounds.x
74
- x_value -= parent.absolute_x if parent.is_a?(Shape)
74
+ x_value -= parent.absolute_x if parent.is_a?(Shape) && parent.class != Shape
75
75
  x_value
76
76
  end
77
77
 
78
78
  # Logical y coordinate relative to parent
79
79
  def y
80
80
  y_value = bounds.y
81
- y_value -= parent.absolute_y if parent.is_a?(Shape)
81
+ y_value -= parent.absolute_y if parent.is_a?(Shape) && parent.class != Shape
82
82
  y_value
83
83
  end
84
84
 
@@ -91,7 +91,7 @@ module Glimmer
91
91
  end
92
92
 
93
93
  def absolute_x1
94
- if parent.is_a?(Shape)
94
+ if parent.is_a?(Shape) && parent.class != Shape
95
95
  parent.absolute_x + x1
96
96
  else
97
97
  x1
@@ -99,7 +99,7 @@ module Glimmer
99
99
  end
100
100
 
101
101
  def absolute_y1
102
- if parent.is_a?(Shape)
102
+ if parent.is_a?(Shape) && parent.class != Shape
103
103
  parent.absolute_y + y1
104
104
  else
105
105
  y1
@@ -107,7 +107,7 @@ module Glimmer
107
107
  end
108
108
 
109
109
  def absolute_x2
110
- if parent.is_a?(Shape)
110
+ if parent.is_a?(Shape) && parent.class != Shape
111
111
  parent.absolute_x + x2.to_f
112
112
  else
113
113
  x2
@@ -115,7 +115,7 @@ module Glimmer
115
115
  end
116
116
 
117
117
  def absolute_y2
118
- if parent.is_a?(Shape)
118
+ if parent.is_a?(Shape) && parent.class != Shape
119
119
  parent.absolute_y + y2.to_f
120
120
  else
121
121
  y2
@@ -34,6 +34,12 @@ module Glimmer
34
34
  include_package 'org.eclipse.swt.graphics'
35
35
  include_package 'org.eclipse.swt.widgets'
36
36
 
37
+ ATTRIBUTE_ALIASES = {
38
+ 'rotation' => 'rotate',
39
+ 'translation' => 'translate',
40
+ 'inversion' => 'invert',
41
+ }
42
+
37
43
  attr_reader :swt_transform, :parent
38
44
 
39
45
  def initialize(parent, *args, swt_transform: nil, multiply: false)
@@ -81,10 +87,11 @@ module Glimmer
81
87
  end
82
88
 
83
89
  def has_attribute?(attribute_name, *args)
84
- Glimmer::SWT::DisplayProxy.instance.auto_exec { @swt_transform.respond_to?(attribute_name) } || super
90
+ ATTRIBUTE_ALIASES.keys.include?(attribute_name.to_s) || Glimmer::SWT::DisplayProxy.instance.auto_exec { @swt_transform.respond_to?(attribute_name) } || super
85
91
  end
86
92
 
87
93
  def set_attribute(attribute_name, *args)
94
+ attribute_name = ATTRIBUTE_ALIASES[attribute_name.to_s] || attribute_name
88
95
  if @swt_transform.respond_to?(attribute_name)
89
96
  Glimmer::SWT::DisplayProxy.instance.auto_exec { @swt_transform.send(attribute_name, *args) }
90
97
  else
@@ -92,6 +99,11 @@ module Glimmer
92
99
  end
93
100
  end
94
101
 
102
+ def get_attribute(attribute_name)
103
+ attribute_name = ATTRIBUTE_ALIASES[attribute_name.to_s] || attribute_name
104
+ super(attribute_name)
105
+ end
106
+
95
107
  def method_missing(method_name, *args, &block)
96
108
  result = Glimmer::SWT::DisplayProxy.instance.auto_exec { @swt_transform.send(method_name, *args, &block) }
97
109
  result.nil? ? self : result
@@ -25,11 +25,11 @@ require 'bigdecimal'
25
25
  class HelloCanvasAnimation
26
26
  include Glimmer::UI::CustomShell
27
27
 
28
- # data-bindable attributes (names must vary from attribute names on animation)
29
- attr_accessor :animation_every, :animation_frame_count, :animation_duration_limit, :animation_started, :animation_finished
28
+ attr_accessor :animation_every, :animation_fps, :animation_frame_count, :animation_duration_limit, :animation_started, :animation_finished
30
29
 
31
30
  before_body {
32
31
  @animation_every = 0.050 # seconds
32
+ @animation_fps = 0
33
33
  @animation_frame_count = 100
34
34
  @animation_duration_limit = 0 # seconds
35
35
  @animation_started = true
@@ -69,14 +69,14 @@ class HelloCanvasAnimation
69
69
  text 'every'
70
70
  }
71
71
  label {
72
- text 'frame count (0=unlimited)'
72
+ text 'frames per second'
73
73
  }
74
74
 
75
75
  # row 3
76
76
  spinner {
77
77
  layout_data(:fill, :center, true, false)
78
78
  digits 3
79
- minimum 1
79
+ minimum 0
80
80
  maximum 100
81
81
  selection <=> [self, :animation_every, on_read: ->(v) {(BigDecimal(v.to_s)*1000).to_f}, on_write: ->(v) {(BigDecimal(v.to_s)/1000).to_f}]
82
82
  }
@@ -84,16 +84,24 @@ class HelloCanvasAnimation
84
84
  layout_data(:fill, :center, true, false)
85
85
  minimum 0
86
86
  maximum 100
87
- selection <=> [self, :animation_frame_count]
87
+ selection <=> [self, :animation_fps]
88
88
  }
89
89
 
90
90
  # row 4
91
+ label {
92
+ text 'frame count (0=unlimited)'
93
+ }
91
94
  label {
92
95
  text 'duration limit (0=unlimited)'
93
96
  }
94
- label # filler
95
97
 
96
98
  # row 5
99
+ spinner {
100
+ layout_data(:fill, :center, true, false)
101
+ minimum 0
102
+ maximum 100
103
+ selection <=> [self, :animation_frame_count]
104
+ }
97
105
  spinner {
98
106
  layout_data(:fill, :center, true, false)
99
107
  minimum 0
@@ -108,11 +116,12 @@ class HelloCanvasAnimation
108
116
  height_hint 320
109
117
  }
110
118
  @animation = animation {
111
- every <= [self, :animation_every]
112
- frame_count <= [self, :animation_frame_count]
113
- duration_limit <= [self, :animation_duration_limit]
114
- started <=> [self, :animation_started]
115
- finished <=> [self, :animation_finished]
119
+ every <= [self, :animation_every]
120
+ fps <= [self, :animation_fps]
121
+ frame_count <= [self, :animation_frame_count]
122
+ duration_limit <= [self, :animation_duration_limit]
123
+ started <=> [self, :animation_started]
124
+ finished <=> [self, :animation_finished]
116
125
 
117
126
  frame { |index|
118
127
  background rgb(index%100, index%100 + 100, index%55 + 200)
@@ -124,6 +133,16 @@ class HelloCanvasAnimation
124
133
  }
125
134
  }
126
135
  }
136
+
137
+ def animation_every=(value)
138
+ @animation_every = value
139
+ self.animation_fps = 0 if @animation_every.to_f > 0
140
+ end
141
+
142
+ def animation_fps=(value)
143
+ @animation_fps = value
144
+ self.animation_every = 0 if @animation_fps.to_f > 0
145
+ end
127
146
  end
128
147
 
129
148
  HelloCanvasAnimation.launch
@@ -13,28 +13,29 @@ shell {
13
13
 
14
14
  image(glimmer_logo, 0, 0) {
15
15
  transform {
16
- translate 110, 110
17
- rotate 90
16
+ translation 110, 110
17
+ rotation 90
18
18
  scale 0.21, 0.21
19
+ # also supports inversion, identity, shear, and multiplication {transform properties}
19
20
  }
20
21
  }
21
22
  image(glimmer_logo, 0, 0) {
22
23
  transform {
23
- translate 110, 220
24
+ translation 110, 220
24
25
  scale 0.21, 0.21
25
26
  }
26
27
  }
27
28
  image(glimmer_logo, 0, 0) {
28
29
  transform {
29
- translate 220, 220
30
- rotate 270
30
+ translation 220, 220
31
+ rotation 270
31
32
  scale 0.21, 0.21
32
33
  }
33
34
  }
34
35
  image(glimmer_logo, 0, 0) {
35
36
  transform {
36
- translate 220, 110
37
- rotate 180
37
+ translation 220, 110
38
+ rotation 180
38
39
  scale 0.21, 0.21
39
40
  }
40
41
  }
@@ -0,0 +1,57 @@
1
+ # Copyright (c) 2007-2021 Andy Maleh
2
+ #
3
+ # Permission is hereby granted, free of charge, to any person obtaining
4
+ # a copy of this software and associated documentation files (the
5
+ # "Software"), to deal in the Software without restriction, including
6
+ # without limitation the rights to use, copy, modify, merge, publish,
7
+ # distribute, sublicense, and/or sell copies of the Software, and to
8
+ # permit persons to whom the Software is furnished to do so, subject to
9
+ # the following conditions:
10
+ #
11
+ # The above copyright notice and this permission notice shall be
12
+ # included in all copies or substantial portions of the Software.
13
+ #
14
+ # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21
+
22
+ require 'glimmer-dsl-swt'
23
+
24
+ class HelloScale
25
+ include Glimmer::UI::CustomShell
26
+
27
+ attr_accessor :value
28
+
29
+ before_body {
30
+ @value = 50
31
+ }
32
+
33
+ body {
34
+ shell {
35
+ row_layout(:vertical) {
36
+ fill true
37
+ center true
38
+ }
39
+
40
+ text 'Hello, Scale!'
41
+
42
+ label(:center) {
43
+ text <= [self, :value]
44
+ }
45
+
46
+ scale { # optionally takes :vertical or :horizontal (default) SWT style
47
+ minimum 0
48
+ maximum 100
49
+ selection <=> [self, :value]
50
+ }
51
+
52
+ }
53
+
54
+ }
55
+ end
56
+
57
+ HelloScale.launch
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: glimmer-dsl-swt
3
3
  version: !ruby/object:Gem::Version
4
- version: 4.20.8.0
4
+ version: 4.20.10.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Andy Maleh
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-07-19 00:00:00.000000000 Z
11
+ date: 2021-07-22 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  requirement: !ruby/object:Gem::Requirement
@@ -69,7 +69,7 @@ dependencies:
69
69
  requirements:
70
70
  - - ">="
71
71
  - !ruby/object:Gem::Version
72
- version: 0.12.0
72
+ version: 0.13.0
73
73
  - - "<"
74
74
  - !ruby/object:Gem::Version
75
75
  version: 2.0.0
@@ -80,7 +80,7 @@ dependencies:
80
80
  requirements:
81
81
  - - ">="
82
82
  - !ruby/object:Gem::Version
83
- version: 0.12.0
83
+ version: 0.13.0
84
84
  - - "<"
85
85
  - !ruby/object:Gem::Version
86
86
  version: 2.0.0
@@ -610,6 +610,7 @@ files:
610
610
  - samples/hello/hello_radio.rb
611
611
  - samples/hello/hello_radio_group.rb
612
612
  - samples/hello/hello_sash_form.rb
613
+ - samples/hello/hello_scale.rb
613
614
  - samples/hello/hello_shape.rb
614
615
  - samples/hello/hello_shell.rb
615
616
  - samples/hello/hello_spinner.rb