glimmer-dsl-libui 0.11.2 → 0.11.4

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: 664a95631db2e2b9bf943f9843c6954df9dc55ba335e51214d721b376969094c
4
- data.tar.gz: 61bc5b8242902e1273296c74dd74b470930a38cf9c34af48e296e14a91dce2e2
3
+ metadata.gz: 587e29f6be24b8a3f01a9872faa7f421531b36a9534fe4b241d52339dbca503c
4
+ data.tar.gz: d1fe047970b1c482aba434f9c1a3d010099aacca1d9ba320cf0ed07967ac3b83
5
5
  SHA512:
6
- metadata.gz: 7045e3c06a6551286523e8f6564b6b57e86477d4c1693ba8b0852c4e259a69151caa0d945d05187cb9b1d0642274323dc6c5d7dcfe02e8481cc01f227a99e993
7
- data.tar.gz: 5927641112ab6807a6f8f941f1e89d1927f85242bdadf79dd1ed9aa8d52f2707cf9607a702ed730a7f76f9594557fadb9f26415b4e87f6ee03b263740f013205
6
+ metadata.gz: 32da548dc373cef2214ce2af6ca329d01691cfdeeda8d9f6f5d85c6878c2d7b02ad1892d50e9f0a443256ef3e54932208c638635f8167e3906500af1eb328c28
7
+ data.tar.gz: 206732983531c55d879818e1ec92c3bba276a8430d5c2785dd80349078145dc3b8e961b31f3510cf10a7cdbfc1e57e15688858b03b91a80baa3bbe00a06b15c0
data/CHANGELOG.md CHANGED
@@ -1,5 +1,14 @@
1
1
  # Change Log
2
2
 
3
+ ## 0.11.4
4
+
5
+ - Fix issue with Content Data-Binding not working
6
+ - Fix issue with not successfully processing layout properties (e.g. `stretchy`) when nested under custom controls/windows
7
+
8
+ ## 0.11.3
9
+
10
+ - Support nesting `on_mouse_*` listeners under `text`
11
+
3
12
  ## 0.11.2
4
13
 
5
14
  - Fix issue with getting error when nesting property content under custom controls/shapes/windows (fixes `examples/basic_custom_shape.rb`)
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 LibUI 0.11.2
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 LibUI 0.11.4
2
2
  ## Prerequisite-Free Ruby Desktop Development Cross-Platform Native GUI Library ([Fukuoka Award Winning](http://www.digitalfukuoka.jp/topics/187?locale=ja))
3
3
  ### The Quickest Way From Zero To GUI
4
4
  [![Gem Version](https://badge.fury.io/rb/glimmer-dsl-libui.svg)](http://badge.fury.io/rb/glimmer-dsl-libui)
@@ -431,7 +431,7 @@ gem install glimmer-dsl-libui
431
431
  Or install via Bundler `Gemfile`:
432
432
 
433
433
  ```ruby
434
- gem 'glimmer-dsl-libui', '~> 0.11.2'
434
+ gem 'glimmer-dsl-libui', '~> 0.11.4'
435
435
  ```
436
436
 
437
437
  Test that installation worked by running the [Glimmer Meta-Example](#examples):
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.11.2
1
+ 0.11.4
@@ -59,7 +59,9 @@ class DynamicForm
59
59
 
60
60
  button('Summarize') {
61
61
  on_clicked do
62
- summary = @user.customizable_attributes.map { |attribute| @user.send(attribute) }.join(', ')
62
+ user_attribute_values = @user.customizable_attributes.map { |attribute| @user.send(attribute) }
63
+ non_blank_user_attribute_values = user_attribute_values.map(&:to_s).reject(&:empty?)
64
+ summary = non_blank_user_attribute_values.join(', ')
63
65
  msg_box('Summary', summary)
64
66
  end
65
67
  }
Binary file
@@ -19,12 +19,12 @@
19
19
  # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
20
  # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21
21
 
22
- require 'glimmer/dsl/static_expression'
22
+ require 'glimmer/dsl/expression'
23
23
 
24
24
  module Glimmer
25
25
  module DSL
26
26
  module Libui
27
- class ContentExpression < StaticExpression
27
+ class ContentExpression < Expression
28
28
  def can_interpret?(parent, keyword, *args, &block)
29
29
  keyword == 'content' &&
30
30
  block_given? &&
@@ -38,7 +38,8 @@ module Glimmer
38
38
  end
39
39
 
40
40
  def add_content(parent, keyword, *args, &block)
41
- options = args.last.is_a?(Hash) ? args.last : {post_add_content: true}
41
+ options = args.last.is_a?(Hash) ? args.last : {}
42
+ options[:post_add_content] = true if !options.include?(:post_add_content)
42
43
  super
43
44
  parent&.post_add_content if options[:post_add_content]
44
45
  end
@@ -44,7 +44,8 @@ module Glimmer
44
44
  end
45
45
 
46
46
  def add_content(custom_control, keyword, *args, &block)
47
- options = args.last.is_a?(Hash) ? args.last : {post_add_content: true}
47
+ options = args.last.is_a?(Hash) ? args.last : {}
48
+ options[:post_add_content] = true if !options.include?(:post_add_content)
48
49
  # TODO consider avoiding source_location
49
50
  if block.source_location == custom_control.content&.__getobj__&.source_location
50
51
  custom_control.content.call(custom_control) unless custom_control.content.called?
@@ -43,7 +43,8 @@ module Glimmer
43
43
  end
44
44
 
45
45
  def add_content(custom_shape, keyword, *args, &block)
46
- options = args.last.is_a?(Hash) ? args.last : {post_add_content: true}
46
+ options = args.last.is_a?(Hash) ? args.last : {}
47
+ options[:post_add_content] = true if !options.include?(:post_add_content)
47
48
  # TODO consider avoiding source_location
48
49
  if block.source_location == custom_shape.content&.__getobj__&.source_location
49
50
  custom_shape.content.call(custom_shape) unless custom_shape.content.called?
@@ -48,7 +48,8 @@ module Glimmer
48
48
  end
49
49
 
50
50
  def add_content(parent, keyword, *args, &block)
51
- options = args.last.is_a?(Hash) ? args.last : {post_add_content: true}
51
+ options = args.last.is_a?(Hash) ? args.last : {}
52
+ options[:post_add_content] = true if !options.include?(:post_add_content)
52
53
  super
53
54
  parent&.post_add_content if options[:post_add_content]
54
55
  end
@@ -28,7 +28,8 @@ module Glimmer
28
28
  module Libui
29
29
  class ShineDataBindingExpression < Expression
30
30
  def can_interpret?(parent, keyword, *args, &block)
31
- args.size == 0 and
31
+ keyword != 'content' and
32
+ args.size == 0 and
32
33
  block.nil? and
33
34
  parent.respond_to?(keyword, *args, &block)
34
35
  end
@@ -46,7 +46,8 @@ module Glimmer
46
46
  end
47
47
 
48
48
  def add_content(parent, keyword, *args, &block)
49
- options = args.last.is_a?(Hash) ? args.last : {post_add_content: true}
49
+ options = args.last.is_a?(Hash) ? args.last : {}
50
+ options[:post_add_content] = true if !options.include?(:post_add_content)
50
51
  parent&.post_add_content(block) if options[:post_add_content]
51
52
  end
52
53
  end
@@ -32,8 +32,9 @@ module Glimmer
32
32
  # Follows the Proxy Design Pattern
33
33
  class TextProxy < ControlProxy
34
34
  include Parent
35
+ include PerfectShaped
35
36
  prepend Transformable
36
-
37
+
37
38
  def initialize(keyword, parent, args, &block)
38
39
  @keyword = keyword
39
40
  @parent_proxy = parent
@@ -156,6 +157,69 @@ module Glimmer
156
157
  @draw_text_layout_params
157
158
  end
158
159
 
160
+ def area_proxy
161
+ # TODO eventually reuse this method from Shape
162
+ find_parent_in_ancestors { |parent| parent.nil? || parent.is_a?(ControlProxy::AreaProxy) }
163
+ end
164
+
165
+ def find_parent_in_ancestors(&condition)
166
+ # TODO eventually reuse this method from Shape
167
+ found = self
168
+ until condition.call(found)
169
+ # TODO in the future, support nesting under composite shape where there is parent instead of parent_proxy
170
+ # found = found.respond_to?(:parent_proxy) ? found.parent_proxy : found.parent
171
+ found = found.parent_proxy
172
+ end
173
+ found
174
+ end
175
+
176
+ def can_handle_listener?(listener_name)
177
+ area_proxy.can_handle_listener?(listener_name)
178
+ end
179
+
180
+ def handle_listener(listener_name, &listener)
181
+ area_proxy.handle_listener(listener_name) do |event|
182
+ listener.call(event) if include?(event[:x], event[:y])
183
+ end
184
+ end
185
+
186
+ def perfect_shape
187
+ the_perfect_shape_dependencies = perfect_shape_dependencies
188
+ if the_perfect_shape_dependencies != @perfect_shape_dependencies
189
+ absolute_x, absolute_y, width, height = @perfect_shape_dependencies = the_perfect_shape_dependencies
190
+ @perfect_shape = PerfectShape::Rectangle.new(x: absolute_x, y: absolute_y, width: width, height: height)
191
+ end
192
+ @perfect_shape
193
+ end
194
+
195
+ def perfect_shape_dependencies
196
+ # TODO support absolute_x and absolute_y with relative positioning in the future
197
+ absolute_x = x
198
+ absolute_y = y
199
+ [absolute_x, absolute_y, extent_width, extent_height]
200
+ end
201
+
202
+ def extent_width
203
+ if @extent_width.to_f > 0
204
+ @extent_width
205
+ else
206
+ width
207
+ end
208
+ end
209
+
210
+ def extent_height
211
+ if @extent_height.to_f > 0
212
+ @extent_height
213
+ else
214
+ children_max_size = children.map(&:font).map {|font| font[:size] if font.respond_to?(:[]) }.compact.max
215
+ if children_max_size.to_f > 0
216
+ children_max_size
217
+ else
218
+ @default_font[:size]
219
+ end
220
+ end
221
+ end
222
+
159
223
  private
160
224
 
161
225
  def build_control
@@ -169,6 +233,16 @@ module Glimmer
169
233
  draw_brush.B = (draw_brush_args[:b] || draw_brush_args[:blue]).to_f / 255.0
170
234
  draw_brush.A = (draw_brush_args[:a] || draw_brush_args[:alpha])
171
235
  end
236
+
237
+ def calculate_extents
238
+ # TODO fix implementation once libui binding project responds about this
239
+ # as it always returns 0,0 right now
240
+ extent_width = Fiddle::Pointer.malloc(Fiddle::SIZEOF_DOUBLE*8)
241
+ extent_height = Fiddle::Pointer.malloc(Fiddle::SIZEOF_DOUBLE*8)
242
+ ::LibUI.draw_text_layout_extents(@libui, extent_width, extent_height)
243
+ @extent_width = extent_width[0, Fiddle::SIZEOF_DOUBLE*8].unpack1('i')
244
+ @extent_height = extent_height[0, Fiddle::SIZEOF_DOUBLE*8].unpack1('i')
245
+ end
172
246
  end
173
247
  end
174
248
  end
@@ -104,11 +104,11 @@ module Glimmer
104
104
 
105
105
  def content_size(*args)
106
106
  if args.empty?
107
- width = Fiddle::Pointer.malloc(8)
108
- height = Fiddle::Pointer.malloc(8)
107
+ width = Fiddle::Pointer.malloc(64)
108
+ height = Fiddle::Pointer.malloc(64)
109
109
  ::LibUI.window_content_size(@libui, width, height)
110
- width = width[0, 8].unpack1('i')
111
- height = height[0, 8].unpack1('i')
110
+ width = width[0, 64].unpack1('i')
111
+ height = height[0, 64].unpack1('i')
112
112
  [width, height]
113
113
  else
114
114
  args = args.first if args.size == 1 && args.first.is_a?(Array)
@@ -142,7 +142,10 @@ module Glimmer
142
142
  # Subclasses may override to perform post add_content work (normally must call super)
143
143
  def post_add_content
144
144
  unless @content_added
145
- @parent_proxy&.post_initialize_child(self)
145
+ if CustomControl.custom_controls_being_interpreted.last.nil? ||
146
+ CustomControl.custom_controls_being_interpreted.last.parent_proxy != @parent_proxy
147
+ @parent_proxy&.post_initialize_child(self)
148
+ end
146
149
  @content_added = true
147
150
  end
148
151
  end
@@ -52,16 +52,6 @@ module Glimmer
52
52
  result ||= can_handle_listener?(method_name)
53
53
  result ||= @body_root.respond_to?(method_name, *args, &block)
54
54
  end
55
-
56
- # Returns content block if used as an attribute reader (no args)
57
- # Otherwise, if a block is passed, it adds it as content to this custom control
58
- def content(&block)
59
- if block_given?
60
- Glimmer::DSL::Engine.add_content(self, Glimmer::DSL::Libui::CustomControlExpression.new, self.class.keyword, &block)
61
- else
62
- @content
63
- end
64
- end
65
55
  end
66
56
 
67
57
  super_module_included do |klass|
@@ -193,11 +183,16 @@ module Glimmer
193
183
  def after_body(&block)
194
184
  @after_body_block = block
195
185
  end
186
+
187
+ def custom_controls_being_interpreted
188
+ @custom_controls_being_interpreted ||= []
189
+ end
196
190
  end
197
191
 
198
192
  attr_reader :body_root, :libui, :parent, :parent_proxy, :args, :keyword, :content, :options
199
193
 
200
194
  def initialize(keyword, parent, args, options, &content)
195
+ CustomControl.custom_controls_being_interpreted << self
201
196
  @parent_proxy = @parent = parent
202
197
  options ||= {}
203
198
  @options = self.class.options.merge(options)
@@ -220,7 +215,8 @@ module Glimmer
220
215
  end
221
216
 
222
217
  def post_add_content
223
- # No Op by default
218
+ @parent_proxy&.post_initialize_child(@body_root)
219
+ Glimmer::LibUI::CustomControl.custom_controls_being_interpreted.pop
224
220
  end
225
221
 
226
222
  def observer_registrations
@@ -243,6 +239,21 @@ module Glimmer
243
239
  !method(method_name)&.source_location&.first&.include?('glimmer/dsl/engine.rb') and
244
240
  !method(method_name)&.source_location&.first&.include?('glimmer/libui/control_proxy.rb')
245
241
  end
242
+
243
+ # Returns content block if used as an attribute reader (no args)
244
+ # Otherwise, if a block is passed, it adds it as content to this custom control
245
+ def content(*args, &block)
246
+ if args.empty?
247
+ if block_given?
248
+ Glimmer::DSL::Engine.add_content(self, Glimmer::DSL::Libui::CustomControlExpression.new, self.class.keyword, &block)
249
+ else
250
+ @content
251
+ end
252
+ else
253
+ # delegate to GUI DSL ContentExpression
254
+ super
255
+ end
256
+ end
246
257
 
247
258
  private
248
259
 
@@ -52,16 +52,6 @@ module Glimmer
52
52
  result ||= can_handle_listener?(method_name)
53
53
  result ||= @body_root.respond_to?(method_name, *args, &block)
54
54
  end
55
-
56
- # Returns content block if used as an attribute reader (no args)
57
- # Otherwise, if a block is passed, it adds it as content to this custom shape
58
- def content(&block)
59
- if block_given?
60
- Glimmer::DSL::Engine.add_content(self, Glimmer::DSL::Libui::CustomShapeExpression.new, self.class.keyword, &block)
61
- else
62
- @content
63
- end
64
- end
65
55
  end
66
56
 
67
57
  super_module_included do |klass|
@@ -240,6 +230,21 @@ module Glimmer
240
230
  !method(method_name)&.source_location&.first&.include?('glimmer/dsl/engine.rb') and
241
231
  !method(method_name)&.source_location&.first&.include?('glimmer/libui/shape.rb')
242
232
  end
233
+
234
+ # Returns content block if used as an attribute reader (no args)
235
+ # Otherwise, if a block is passed, it adds it as content to this custom shape
236
+ def content(*args, &block)
237
+ if args.empty?
238
+ if block_given?
239
+ Glimmer::DSL::Engine.add_content(self, Glimmer::DSL::Libui::CustomShapeExpression.new, self.class.keyword, &block)
240
+ else
241
+ @content
242
+ end
243
+ else
244
+ # delegate to GUI DSL ContentExpression
245
+ super
246
+ end
247
+ end
243
248
 
244
249
  private
245
250
 
@@ -15,13 +15,14 @@ module Glimmer
15
15
  # determining if a point lies on the outline (e.g. makes it easier to select
16
16
  # a shape by mouse)
17
17
  def contain?(*point, outline: false, distance_tolerance: 0)
18
+ # TODO inverse transform point with `uiDrawMatrixTransformPoint` before checking containment
18
19
  perfect_shape&.contain?(*point, outline: outline, distance_tolerance: distance_tolerance)
19
20
  end
20
21
 
21
22
  # Returns if shape includes point on the inside when filled
22
23
  # or if shape includes point on the outline when stroked
23
24
  def include?(*point)
24
- if fill.empty?
25
+ if respond_to?(:fill) && fill.empty?
25
26
  # TODO check if distance_tolerance should be half the thickness in case it is checked against both sides of out and in
26
27
  contain?(*point, outline: true, distance_tolerance: ((stroke[:thickness] || 1) - 1))
27
28
  else
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: glimmer-dsl-libui
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.11.2
4
+ version: 0.11.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Andy Maleh
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2023-11-17 00:00:00.000000000 Z
11
+ date: 2023-11-20 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: glimmer