glimmer-dsl-swt 4.18.4.0 → 4.18.4.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (167) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +46 -0
  3. data/LICENSE.txt +20 -20
  4. data/README.md +84 -5078
  5. data/RUBY_VERSION +1 -1
  6. data/VERSION +1 -1
  7. data/bin/girb +31 -31
  8. data/bin/girb_runner.rb +34 -34
  9. data/bin/glimmer +26 -26
  10. data/docs/reference/GLIMMER_COMMAND.md +591 -0
  11. data/docs/reference/GLIMMER_CONFIGURATION.md +183 -0
  12. data/docs/reference/GLIMMER_GIRB.md +30 -0
  13. data/docs/reference/GLIMMER_GUI_DSL_SYNTAX.md +3251 -0
  14. data/docs/reference/GLIMMER_PACKAGING_AND_DISTRIBUTION.md +202 -0
  15. data/docs/reference/GLIMMER_SAMPLES.md +676 -0
  16. data/docs/reference/GLIMMER_STYLE_GUIDE.md +14 -0
  17. data/glimmer-dsl-swt.gemspec +16 -8
  18. data/lib/ext/glimmer.rb +41 -41
  19. data/lib/ext/glimmer/config.rb +167 -167
  20. data/lib/ext/rouge/themes/glimmer.rb +29 -29
  21. data/lib/glimmer-dsl-swt.rb +44 -44
  22. data/lib/glimmer/Rakefile +26 -26
  23. data/lib/glimmer/data_binding/list_selection_binding.rb +72 -72
  24. data/lib/glimmer/data_binding/observable_widget.rb +38 -38
  25. data/lib/glimmer/data_binding/shine.rb +44 -44
  26. data/lib/glimmer/data_binding/table_items_binding.rb +89 -89
  27. data/lib/glimmer/data_binding/tree_items_binding.rb +108 -108
  28. data/lib/glimmer/data_binding/widget_binding.rb +73 -73
  29. data/lib/glimmer/dsl/swt/animation_expression.rb +43 -43
  30. data/lib/glimmer/dsl/swt/async_exec_expression.rb +35 -35
  31. data/lib/glimmer/dsl/swt/bind_expression.rb +58 -58
  32. data/lib/glimmer/dsl/swt/block_property_expression.rb +41 -41
  33. data/lib/glimmer/dsl/swt/checkbox_group_selection_data_binding_expression.rb +61 -61
  34. data/lib/glimmer/dsl/swt/color_expression.rb +40 -40
  35. data/lib/glimmer/dsl/swt/column_properties_expression.rb +45 -45
  36. data/lib/glimmer/dsl/swt/combo_selection_data_binding_expression.rb +67 -67
  37. data/lib/glimmer/dsl/swt/cursor_expression.rb +44 -44
  38. data/lib/glimmer/dsl/swt/custom_widget_expression.rb +3 -3
  39. data/lib/glimmer/dsl/swt/data_binding_expression.rb +55 -55
  40. data/lib/glimmer/dsl/swt/dialog_expression.rb +48 -48
  41. data/lib/glimmer/dsl/swt/directory_dialog_expression.rb +48 -48
  42. data/lib/glimmer/dsl/swt/display_expression.rb +40 -40
  43. data/lib/glimmer/dsl/swt/dnd_expression.rb +46 -46
  44. data/lib/glimmer/dsl/swt/dsl.rb +63 -63
  45. data/lib/glimmer/dsl/swt/exec_expression.rb +1 -1
  46. data/lib/glimmer/dsl/swt/expand_item_expression.rb +60 -60
  47. data/lib/glimmer/dsl/swt/file_dialog_expression.rb +48 -48
  48. data/lib/glimmer/dsl/swt/font_expression.rb +49 -49
  49. data/lib/glimmer/dsl/swt/image_expression.rb +50 -50
  50. data/lib/glimmer/dsl/swt/layout_data_expression.rb +46 -46
  51. data/lib/glimmer/dsl/swt/layout_expression.rb +50 -50
  52. data/lib/glimmer/dsl/swt/list_selection_data_binding_expression.rb +65 -65
  53. data/lib/glimmer/dsl/swt/menu_bar_expression.rb +54 -54
  54. data/lib/glimmer/dsl/swt/menu_expression.rb +53 -53
  55. data/lib/glimmer/dsl/swt/message_box_expression.rb +54 -54
  56. data/lib/glimmer/dsl/swt/multiply_expression.rb +53 -53
  57. data/lib/glimmer/dsl/swt/observe_expression.rb +8 -5
  58. data/lib/glimmer/dsl/swt/property_expression.rb +46 -46
  59. data/lib/glimmer/dsl/swt/radio_group_selection_data_binding_expression.rb +61 -61
  60. data/lib/glimmer/dsl/swt/rgb_expression.rb +33 -33
  61. data/lib/glimmer/dsl/swt/rgba_expression.rb +33 -33
  62. data/lib/glimmer/dsl/swt/shape_expression.rb +54 -54
  63. data/lib/glimmer/dsl/swt/shell_expression.rb +46 -46
  64. data/lib/glimmer/dsl/swt/swt_expression.rb +46 -46
  65. data/lib/glimmer/dsl/swt/sync_exec_expression.rb +36 -36
  66. data/lib/glimmer/dsl/swt/tab_item_expression.rb +54 -54
  67. data/lib/glimmer/dsl/swt/table_items_data_binding_expression.rb +52 -52
  68. data/lib/glimmer/dsl/swt/timer_exec_expression.rb +35 -0
  69. data/lib/glimmer/dsl/swt/transform_expression.rb +55 -55
  70. data/lib/glimmer/dsl/swt/tree_items_data_binding_expression.rb +52 -52
  71. data/lib/glimmer/dsl/swt/tree_properties_expression.rb +47 -47
  72. data/lib/glimmer/dsl/swt/widget_expression.rb +66 -66
  73. data/lib/glimmer/dsl/swt/widget_listener_expression.rb +53 -53
  74. data/lib/glimmer/rake_task.rb +220 -220
  75. data/lib/glimmer/rake_task/list.rb +97 -97
  76. data/lib/glimmer/rake_task/package.rb +139 -139
  77. data/lib/glimmer/rake_task/scaffold.rb +765 -765
  78. data/lib/glimmer/swt/color_proxy.rb +107 -107
  79. data/lib/glimmer/swt/cursor_proxy.rb +66 -66
  80. data/lib/glimmer/swt/custom/animation.rb +12 -8
  81. data/lib/glimmer/swt/custom/checkbox_group.rb +181 -181
  82. data/lib/glimmer/swt/custom/code_text.rb +62 -28
  83. data/lib/glimmer/swt/custom/drawable.rb +49 -49
  84. data/lib/glimmer/swt/custom/radio_group.rb +176 -176
  85. data/lib/glimmer/swt/custom/shape.rb +5 -3
  86. data/lib/glimmer/swt/date_time_proxy.rb +85 -85
  87. data/lib/glimmer/swt/directory_dialog_proxy.rb +65 -65
  88. data/lib/glimmer/swt/display_proxy.rb +11 -10
  89. data/lib/glimmer/swt/dnd_proxy.rb +51 -51
  90. data/lib/glimmer/swt/expand_item_proxy.rb +97 -97
  91. data/lib/glimmer/swt/file_dialog_proxy.rb +66 -66
  92. data/lib/glimmer/swt/font_proxy.rb +94 -94
  93. data/lib/glimmer/swt/image_proxy.rb +184 -184
  94. data/lib/glimmer/swt/layout_data_proxy.rb +105 -105
  95. data/lib/glimmer/swt/layout_proxy.rb +112 -109
  96. data/lib/glimmer/swt/menu_proxy.rb +126 -126
  97. data/lib/glimmer/swt/message_box_proxy.rb +89 -89
  98. data/lib/glimmer/swt/packages.rb +37 -37
  99. data/lib/glimmer/swt/properties.rb +49 -49
  100. data/lib/glimmer/swt/sash_form_proxy.rb +53 -53
  101. data/lib/glimmer/swt/scrolled_composite_proxy.rb +37 -37
  102. data/lib/glimmer/swt/shell_proxy.rb +1 -1
  103. data/lib/glimmer/swt/style_constantizable.rb +157 -157
  104. data/lib/glimmer/swt/styled_text_proxy.rb +38 -38
  105. data/lib/glimmer/swt/swt_proxy.rb +59 -59
  106. data/lib/glimmer/swt/tab_item_proxy.rb +91 -91
  107. data/lib/glimmer/swt/table_column_proxy.rb +57 -57
  108. data/lib/glimmer/swt/table_proxy.rb +2 -2
  109. data/lib/glimmer/swt/transform_proxy.rb +109 -109
  110. data/lib/glimmer/swt/tree_proxy.rb +145 -145
  111. data/lib/glimmer/swt/widget_listener_proxy.rb +64 -64
  112. data/lib/glimmer/swt/widget_proxy.rb +14 -4
  113. data/lib/glimmer/ui/custom_shell.rb +82 -82
  114. data/lib/glimmer/ui/custom_widget.rb +17 -0
  115. data/lib/glimmer/util/proc_tracker.rb +39 -39
  116. data/samples/elaborate/contact_manager.rb +142 -142
  117. data/samples/elaborate/contact_manager/contact.rb +32 -32
  118. data/samples/elaborate/contact_manager/contact_manager_presenter.rb +47 -47
  119. data/samples/elaborate/contact_manager/contact_repository.rb +169 -169
  120. data/samples/elaborate/login.rb +123 -123
  121. data/samples/elaborate/meta_sample.rb +15 -4
  122. data/samples/elaborate/tetris.rb +14 -17
  123. data/samples/elaborate/tetris/model/block.rb +48 -48
  124. data/samples/elaborate/tetris/model/game.rb +1 -2
  125. data/samples/elaborate/tetris/model/past_game.rb +39 -39
  126. data/samples/elaborate/tetris/view/high_score_dialog.rb +0 -7
  127. data/samples/elaborate/tetris/view/playfield.rb +1 -1
  128. data/samples/elaborate/tetris/view/tetris_menu_bar.rb +13 -11
  129. data/samples/elaborate/tic_tac_toe.rb +76 -76
  130. data/samples/elaborate/tic_tac_toe/board.rb +145 -145
  131. data/samples/elaborate/tic_tac_toe/cell.rb +48 -48
  132. data/samples/elaborate/user_profile.rb +76 -76
  133. data/samples/hello/hello_browser.rb +31 -31
  134. data/samples/hello/hello_button.rb +46 -46
  135. data/samples/hello/hello_canvas.rb +64 -64
  136. data/samples/hello/hello_canvas_transform.rb +1 -1
  137. data/samples/hello/hello_checkbox.rb +85 -85
  138. data/samples/hello/hello_checkbox_group.rb +71 -71
  139. data/samples/hello/hello_code_text.rb +104 -92
  140. data/samples/hello/hello_combo.rb +63 -63
  141. data/samples/hello/hello_computed.rb +96 -96
  142. data/samples/hello/hello_computed/contact.rb +42 -42
  143. data/samples/hello/hello_custom_shell.rb +155 -155
  144. data/samples/hello/hello_custom_widget.rb +86 -86
  145. data/samples/hello/hello_date_time.rb +63 -63
  146. data/samples/hello/hello_dialog.rb +78 -78
  147. data/samples/hello/hello_directory_dialog.rb +60 -60
  148. data/samples/hello/hello_drag_and_drop.rb +50 -50
  149. data/samples/hello/hello_expand_bar.rb +110 -110
  150. data/samples/hello/hello_file_dialog.rb +60 -60
  151. data/samples/hello/hello_group.rb +104 -104
  152. data/samples/hello/hello_link.rb +80 -80
  153. data/samples/hello/hello_list_multi_selection.rb +74 -74
  154. data/samples/hello/hello_list_single_selection.rb +59 -59
  155. data/samples/hello/hello_menu_bar.rb +241 -241
  156. data/samples/hello/hello_message_box.rb +37 -37
  157. data/samples/hello/hello_pop_up_context_menu.rb +84 -84
  158. data/samples/hello/hello_radio.rb +108 -108
  159. data/samples/hello/hello_radio_group.rb +87 -87
  160. data/samples/hello/hello_sash_form.rb +137 -137
  161. data/samples/hello/hello_spinner.rb +69 -69
  162. data/samples/hello/hello_styled_text.rb +138 -138
  163. data/samples/hello/hello_tab.rb +50 -50
  164. data/samples/hello/hello_table.rb +1 -0
  165. data/samples/hello/hello_world.rb +29 -29
  166. metadata +13 -5
  167. data/samples/elaborate/meta_sample/meta_sample_logo.png +0 -0
@@ -1,107 +1,107 @@
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/swt/swt_proxy'
23
- require 'glimmer/swt/display_proxy'
24
-
25
- module Glimmer
26
- module SWT
27
- # Proxy for org.eclipse.swt.graphics.Color
28
- #
29
- # Invoking `#swt_color` returns the SWT Color object wrapped by this proxy
30
- #
31
- # Follows the Proxy Design Pattern and Flyweight Design Pattern (caching memoization)
32
- class ColorProxy
33
- include_package 'org.eclipse.swt.graphics'
34
-
35
- class << self
36
- def flyweight(*args)
37
- flyweight_color_proxies[args] ||= new(*args)
38
- end
39
-
40
- # Flyweight Design Pattern memoization cache. Can be cleared if memory is needed.
41
- def flyweight_color_proxies
42
- @flyweight_color_proxies ||= {}
43
- end
44
- end
45
-
46
- # Initializes a proxy for an SWT Color object
47
- #
48
- # Takes a standard color single argument, rgba 3 args, or rgba 4 args
49
- #
50
- # A standard color is a string/symbol representing one of the
51
- # SWT.COLOR_*** constants like SWT.COLOR_RED, but in underscored string
52
- # format (e.g :color_red).
53
- # Glimmer can also accept standard color names without the color_ prefix,
54
- # and it will automatically figure out the SWT.COLOR_*** constant
55
- # (e.g. :red)
56
- #
57
- # rgb is 3 arguments representing Red, Green, Blue numeric values
58
- #
59
- # rgba is 4 arguments representing Red, Green, Blue, and Alpha numeric values
60
- #
61
- def initialize(*args)
62
- @args = args
63
- ensure_arg_values_within_valid_bounds
64
- end
65
-
66
- def swt_color
67
- unless @swt_color
68
- case @args.size
69
- when 1
70
- if @args.first.is_a?(String) || @args.first.is_a?(Symbol)
71
- standard_color = @args.first
72
- standard_color = "color_#{standard_color}".to_sym unless standard_color.to_s.downcase.include?('color_')
73
- @swt_color = DisplayProxy.instance.swt_display.getSystemColor(SWTProxy[standard_color])
74
- else
75
- @swt_color = @args.first
76
- end
77
- when 3..4
78
- red, green, blue, alpha = @args
79
- @swt_color = Color.new(*[red, green, blue, alpha].compact)
80
- end
81
- end
82
- @swt_color
83
- end
84
-
85
- def method_missing(method, *args, &block)
86
- swt_color.send(method, *args, &block)
87
- rescue => e
88
- Glimmer::Config.logger.debug {"Neither ColorProxy nor #{swt_color.class.name} can handle the method ##{method}"}
89
- super
90
- end
91
-
92
- def respond_to?(method, *args, &block)
93
- super || swt_color.respond_to?(method, *args, &block)
94
- end
95
-
96
- private
97
-
98
- def ensure_arg_values_within_valid_bounds
99
- if @args.to_a.size >= 3
100
- @args = @args.map do |value|
101
- [[value, 255].min, 0].max
102
- end
103
- end
104
- end
105
- end
106
- end
107
- end
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/swt/swt_proxy'
23
+ require 'glimmer/swt/display_proxy'
24
+
25
+ module Glimmer
26
+ module SWT
27
+ # Proxy for org.eclipse.swt.graphics.Color
28
+ #
29
+ # Invoking `#swt_color` returns the SWT Color object wrapped by this proxy
30
+ #
31
+ # Follows the Proxy Design Pattern and Flyweight Design Pattern (caching memoization)
32
+ class ColorProxy
33
+ include_package 'org.eclipse.swt.graphics'
34
+
35
+ class << self
36
+ def flyweight(*args)
37
+ flyweight_color_proxies[args] ||= new(*args)
38
+ end
39
+
40
+ # Flyweight Design Pattern memoization cache. Can be cleared if memory is needed.
41
+ def flyweight_color_proxies
42
+ @flyweight_color_proxies ||= {}
43
+ end
44
+ end
45
+
46
+ # Initializes a proxy for an SWT Color object
47
+ #
48
+ # Takes a standard color single argument, rgba 3 args, or rgba 4 args
49
+ #
50
+ # A standard color is a string/symbol representing one of the
51
+ # SWT.COLOR_*** constants like SWT.COLOR_RED, but in underscored string
52
+ # format (e.g :color_red).
53
+ # Glimmer can also accept standard color names without the color_ prefix,
54
+ # and it will automatically figure out the SWT.COLOR_*** constant
55
+ # (e.g. :red)
56
+ #
57
+ # rgb is 3 arguments representing Red, Green, Blue numeric values
58
+ #
59
+ # rgba is 4 arguments representing Red, Green, Blue, and Alpha numeric values
60
+ #
61
+ def initialize(*args)
62
+ @args = args
63
+ ensure_arg_values_within_valid_bounds
64
+ end
65
+
66
+ def swt_color
67
+ unless @swt_color
68
+ case @args.size
69
+ when 1
70
+ if @args.first.is_a?(String) || @args.first.is_a?(Symbol)
71
+ standard_color = @args.first
72
+ standard_color = "color_#{standard_color}".to_sym unless standard_color.to_s.downcase.include?('color_')
73
+ @swt_color = DisplayProxy.instance.swt_display.getSystemColor(SWTProxy[standard_color])
74
+ else
75
+ @swt_color = @args.first
76
+ end
77
+ when 3..4
78
+ red, green, blue, alpha = @args
79
+ @swt_color = Color.new(*[red, green, blue, alpha].compact)
80
+ end
81
+ end
82
+ @swt_color
83
+ end
84
+
85
+ def method_missing(method, *args, &block)
86
+ swt_color.send(method, *args, &block)
87
+ rescue => e
88
+ Glimmer::Config.logger.debug {"Neither ColorProxy nor #{swt_color.class.name} can handle the method ##{method}"}
89
+ super
90
+ end
91
+
92
+ def respond_to?(method, *args, &block)
93
+ super || swt_color.respond_to?(method, *args, &block)
94
+ end
95
+
96
+ private
97
+
98
+ def ensure_arg_values_within_valid_bounds
99
+ if @args.to_a.size >= 3
100
+ @args = @args.map do |value|
101
+ [[value, 255].min, 0].max
102
+ end
103
+ end
104
+ end
105
+ end
106
+ end
107
+ end
@@ -1,66 +1,66 @@
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/error'
23
- require 'glimmer/swt/swt_proxy'
24
- require 'glimmer/swt/display_proxy'
25
-
26
- module Glimmer
27
- module SWT
28
- # Proxy for org.eclipse.swt.graphics.Cursor
29
- #
30
- # Invoking `#swt_cursor` returns the SWT Cursor object wrapped by this proxy
31
- #
32
- # Follows the Proxy Design Pattern
33
- class CursorProxy
34
- CURSOR_STYLES = org.eclipse.swt.SWT.constants.select {|c| c.to_s.downcase.start_with?('cursor_')}.map {|c| c.to_s.downcase.sub('cursor_', '').to_sym}
35
- ERROR_INVALID_CURSOR_STYLE = " is an invalid cursor style! Valid values are #{CURSOR_STYLES.map(&:to_s).join(", ")}"
36
-
37
- include_package 'org.eclipse.swt.graphics'
38
-
39
- attr_reader :swt_cursor, :cursor_style
40
-
41
- # Builds a new CursorProxy from passed in cursor SWT style (e.g. :appstarting, :hand, or :help)
42
- #
43
- # Cursor SWT styles are those that begin with "CURSOR_" prefix
44
- #
45
- # They are expected to be passed in in short form without the prefix (but would work with the prefix too)
46
- def initialize(cursor_style)
47
- @cursor_style = cursor_style
48
- @cursor_style = SWTProxy.reverse_lookup(@cursor_style).detect { |symbol| symbol.to_s.downcase.start_with?('cursor_') } if cursor_style.is_a?(Integer)
49
- @cursor_style = @cursor_style.to_s.downcase
50
- @cursor_style = @cursor_style.sub(/^cursor\_/, '') if @cursor_style.start_with?('cursor_')
51
- detect_invalid_cursor_style
52
- @swt_cursor = DisplayProxy.instance.swt_display.get_system_cursor(SWTProxy[swt_style])
53
- end
54
-
55
- def swt_style
56
- @swt_style ||= @cursor_style.upcase.start_with?('CURSOR_') ? @cursor_style : "CURSOR_#{@cursor_style}"
57
- end
58
-
59
- private
60
-
61
- def detect_invalid_cursor_style
62
- raise Error, cursor_style.to_s + ERROR_INVALID_CURSOR_STYLE unless CURSOR_STYLES.include?(cursor_style.to_s.downcase.to_sym)
63
- end
64
- end
65
- end
66
- end
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/error'
23
+ require 'glimmer/swt/swt_proxy'
24
+ require 'glimmer/swt/display_proxy'
25
+
26
+ module Glimmer
27
+ module SWT
28
+ # Proxy for org.eclipse.swt.graphics.Cursor
29
+ #
30
+ # Invoking `#swt_cursor` returns the SWT Cursor object wrapped by this proxy
31
+ #
32
+ # Follows the Proxy Design Pattern
33
+ class CursorProxy
34
+ CURSOR_STYLES = org.eclipse.swt.SWT.constants.select {|c| c.to_s.downcase.start_with?('cursor_')}.map {|c| c.to_s.downcase.sub('cursor_', '').to_sym}
35
+ ERROR_INVALID_CURSOR_STYLE = " is an invalid cursor style! Valid values are #{CURSOR_STYLES.map(&:to_s).join(", ")}"
36
+
37
+ include_package 'org.eclipse.swt.graphics'
38
+
39
+ attr_reader :swt_cursor, :cursor_style
40
+
41
+ # Builds a new CursorProxy from passed in cursor SWT style (e.g. :appstarting, :hand, or :help)
42
+ #
43
+ # Cursor SWT styles are those that begin with "CURSOR_" prefix
44
+ #
45
+ # They are expected to be passed in in short form without the prefix (but would work with the prefix too)
46
+ def initialize(cursor_style)
47
+ @cursor_style = cursor_style
48
+ @cursor_style = SWTProxy.reverse_lookup(@cursor_style).detect { |symbol| symbol.to_s.downcase.start_with?('cursor_') } if cursor_style.is_a?(Integer)
49
+ @cursor_style = @cursor_style.to_s.downcase
50
+ @cursor_style = @cursor_style.sub(/^cursor\_/, '') if @cursor_style.start_with?('cursor_')
51
+ detect_invalid_cursor_style
52
+ @swt_cursor = DisplayProxy.instance.swt_display.get_system_cursor(SWTProxy[swt_style])
53
+ end
54
+
55
+ def swt_style
56
+ @swt_style ||= @cursor_style.upcase.start_with?('CURSOR_') ? @cursor_style : "CURSOR_#{@cursor_style}"
57
+ end
58
+
59
+ private
60
+
61
+ def detect_invalid_cursor_style
62
+ raise Error, cursor_style.to_s + ERROR_INVALID_CURSOR_STYLE unless CURSOR_STYLES.include?(cursor_style.to_s.downcase.to_sym)
63
+ end
64
+ end
65
+ end
66
+ end
@@ -26,7 +26,7 @@ module Glimmer
26
26
  module Custom
27
27
  # Represents an animation declaratively
28
28
  class Animation
29
- include Properties # TODO rename to Properties
29
+ include Properties
30
30
 
31
31
  class << self
32
32
  def schedule_frame_animation(animation, &frame_animation_block)
@@ -92,8 +92,10 @@ module Glimmer
92
92
  end
93
93
 
94
94
  def post_add_content
95
- @parent.on_widget_disposed { stop }
96
- start if started?
95
+ if @dispose_listener_registration.nil?
96
+ @dispose_listener_registration = @parent.on_widget_disposed { stop }
97
+ start if started?
98
+ end
97
99
  end
98
100
 
99
101
  # Starts an animation that is indefinite or has never been started before (i.e. having `started: false` option).
@@ -212,11 +214,13 @@ module Glimmer
212
214
  current_cycle_count_index = @cycle_count_index
213
215
  self.class.schedule_frame_animation(self) do
214
216
  if started? && start_number == @start_number && within_duration_limit?
215
- @parent.clear_shapes
216
- @parent.content {
217
- frame_block.call(*block_args)
218
- }
219
- @parent.redraw
217
+ unless @parent.isDisposed
218
+ @parent.clear_shapes
219
+ @parent.content {
220
+ frame_block.call(*block_args)
221
+ }
222
+ @parent.redraw
223
+ end
220
224
  else
221
225
  if stopped? && @frame_index > current_frame_index
222
226
  @started = false
@@ -1,181 +1,181 @@
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/ui/custom_widget'
23
-
24
- module Glimmer
25
- module SWT
26
- module Custom
27
- # A custom widget rendering a group of checkboxes generated via data-binding
28
- class CheckboxGroup
29
- include Glimmer::UI::CustomWidget
30
-
31
- body {
32
- composite # just an empty composite to hold checkboxs upon data-binding `selection`
33
- }
34
-
35
- def items=(text_array)
36
- selection_value = selection
37
- @items = Array[*text_array]
38
- build_checkboxes
39
- end
40
-
41
- def items
42
- @items || []
43
- end
44
-
45
- def selection=(selection_texts)
46
- items.count.times do |index|
47
- checkbox = checkboxes[index]
48
- item = items[index]
49
- label_text = labels[index]&.text
50
- checkbox.selection = selection_texts.to_a.include?(label_text)
51
- end
52
- selection_texts
53
- end
54
-
55
- def selection
56
- selection_indices.map do |selection_index|
57
- labels[selection_index]&.text
58
- end
59
- end
60
-
61
- def selection_indices=(indices)
62
- self.selection=(indices.to_a.map {|index| items[index]})
63
- end
64
- alias select selection_indices=
65
-
66
- def selection_indices
67
- checkboxes.each_with_index.map do |checkbox, index|
68
- index if checkbox.selection
69
- end.to_a.compact
70
- end
71
-
72
- def checkboxes
73
- @checkboxes ||= []
74
- end
75
- alias checks checkboxes
76
-
77
- def labels
78
- @labels ||= []
79
- end
80
-
81
- def can_handle_observation_request?(observation_request)
82
- checkboxes.first&.can_handle_observation_request?(observation_request) || super(observation_request)
83
- end
84
-
85
- def handle_observation_request(observation_request, &block)
86
- observation_requests << [observation_request, block]
87
- delegate_observation_request_to_checkboxes(observation_request, &block)
88
- super
89
- end
90
-
91
- def delegate_observation_request_to_checkboxes(observation_request, &block)
92
- if observation_request != 'on_widget_disposed'
93
- checkboxes.count.times do |index|
94
- checkbox = checkboxes[index]
95
- label = labels[index]
96
- listener_block = lambda do |event|
97
- event.widget = self.swt_widget
98
- block.call(event)
99
- end
100
- if observation_request == 'on_widget_selected'
101
- checkbox.handle_observation_request(observation_request, &listener_block) if checkbox.can_handle_observation_request?(observation_request)
102
- label.handle_observation_request('on_mouse_up', &listener_block)
103
- else
104
- checkbox.handle_observation_request(observation_request, &listener_block) if checkbox.can_handle_observation_request?(observation_request)
105
- label.handle_observation_request(observation_request, &listener_block) if label.can_handle_observation_request?(observation_request)
106
- end
107
- end
108
- end
109
- end
110
-
111
- def observation_requests
112
- @observation_requests ||= Set.new
113
- end
114
-
115
- def has_attribute?(attribute_name, *args)
116
- (@composites.to_a + @checkboxes.to_a + @labels.to_a).map do |widget_proxy|
117
- return true if widget_proxy.has_attribute?(attribute_name, *args)
118
- end
119
- super
120
- end
121
-
122
- def set_attribute(attribute_name, *args)
123
- excluded_attributes = ['selection']
124
- unless excluded_attributes.include?(attribute_name.to_s)
125
- (@composites.to_a + @checkboxes.to_a + @labels.to_a).each do |widget_proxy|
126
- widget_proxy.set_attribute(attribute_name, *args) if widget_proxy.has_attribute?(attribute_name, *args)
127
- end
128
- end
129
- super
130
- end
131
-
132
- private
133
-
134
- def build_checkboxes
135
- current_selection = selection
136
- @composites.to_a.each(&:dispose)
137
- @checkboxes = []
138
- @labels = []
139
- @composites = []
140
- items.each do |item|
141
- body_root.content {
142
- @composites << composite {
143
- grid_layout(2, false) {
144
- margin_width 0
145
- margin_height 0
146
- horizontal_spacing 0
147
- vertical_spacing 0
148
- }
149
- checkboxes << checkbox { |checkbox_proxy|
150
- on_widget_selected {
151
- self.selection_indices = checkboxes.each_with_index.map {|cb, i| i if cb.selection}.to_a.compact
152
- }
153
- }
154
- labels << label { |label_proxy|
155
- layout_data :fill, :center, true, false
156
- text item
157
- on_mouse_up { |event|
158
- found_text = labels.each_with_index.detect {|l, i| event.widget == l.swt_widget}[0]&.text
159
- selection_values = self.selection
160
- if selection_values.include?(found_text)
161
- selection_values.delete(found_text)
162
- else
163
- selection_values << found_text
164
- end
165
- self.selection = selection_values
166
- }
167
- }
168
- }
169
- }
170
- end
171
- observation_requests.to_a.each do |observation_request, block|
172
- delegate_observation_request_to_checkboxes(observation_request, &block)
173
- end
174
- self.selection = current_selection
175
- end
176
- end
177
-
178
- CheckGroup = CheckboxGroup
179
- end
180
- end
181
- end
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/ui/custom_widget'
23
+
24
+ module Glimmer
25
+ module SWT
26
+ module Custom
27
+ # A custom widget rendering a group of checkboxes generated via data-binding
28
+ class CheckboxGroup
29
+ include Glimmer::UI::CustomWidget
30
+
31
+ body {
32
+ composite # just an empty composite to hold checkboxs upon data-binding `selection`
33
+ }
34
+
35
+ def items=(text_array)
36
+ selection_value = selection
37
+ @items = Array[*text_array]
38
+ build_checkboxes
39
+ end
40
+
41
+ def items
42
+ @items || []
43
+ end
44
+
45
+ def selection=(selection_texts)
46
+ items.count.times do |index|
47
+ checkbox = checkboxes[index]
48
+ item = items[index]
49
+ label_text = labels[index]&.text
50
+ checkbox.selection = selection_texts.to_a.include?(label_text)
51
+ end
52
+ selection_texts
53
+ end
54
+
55
+ def selection
56
+ selection_indices.map do |selection_index|
57
+ labels[selection_index]&.text
58
+ end
59
+ end
60
+
61
+ def selection_indices=(indices)
62
+ self.selection=(indices.to_a.map {|index| items[index]})
63
+ end
64
+ alias select selection_indices=
65
+
66
+ def selection_indices
67
+ checkboxes.each_with_index.map do |checkbox, index|
68
+ index if checkbox.selection
69
+ end.to_a.compact
70
+ end
71
+
72
+ def checkboxes
73
+ @checkboxes ||= []
74
+ end
75
+ alias checks checkboxes
76
+
77
+ def labels
78
+ @labels ||= []
79
+ end
80
+
81
+ def can_handle_observation_request?(observation_request)
82
+ checkboxes.first&.can_handle_observation_request?(observation_request) || super(observation_request)
83
+ end
84
+
85
+ def handle_observation_request(observation_request, &block)
86
+ observation_requests << [observation_request, block]
87
+ delegate_observation_request_to_checkboxes(observation_request, &block)
88
+ super
89
+ end
90
+
91
+ def delegate_observation_request_to_checkboxes(observation_request, &block)
92
+ if observation_request != 'on_widget_disposed'
93
+ checkboxes.count.times do |index|
94
+ checkbox = checkboxes[index]
95
+ label = labels[index]
96
+ listener_block = lambda do |event|
97
+ event.widget = self.swt_widget
98
+ block.call(event)
99
+ end
100
+ if observation_request == 'on_widget_selected'
101
+ checkbox.handle_observation_request(observation_request, &listener_block) if checkbox.can_handle_observation_request?(observation_request)
102
+ label.handle_observation_request('on_mouse_up', &listener_block)
103
+ else
104
+ checkbox.handle_observation_request(observation_request, &listener_block) if checkbox.can_handle_observation_request?(observation_request)
105
+ label.handle_observation_request(observation_request, &listener_block) if label.can_handle_observation_request?(observation_request)
106
+ end
107
+ end
108
+ end
109
+ end
110
+
111
+ def observation_requests
112
+ @observation_requests ||= Set.new
113
+ end
114
+
115
+ def has_attribute?(attribute_name, *args)
116
+ (@composites.to_a + @checkboxes.to_a + @labels.to_a).map do |widget_proxy|
117
+ return true if widget_proxy.has_attribute?(attribute_name, *args)
118
+ end
119
+ super
120
+ end
121
+
122
+ def set_attribute(attribute_name, *args)
123
+ excluded_attributes = ['selection']
124
+ unless excluded_attributes.include?(attribute_name.to_s)
125
+ (@composites.to_a + @checkboxes.to_a + @labels.to_a).each do |widget_proxy|
126
+ widget_proxy.set_attribute(attribute_name, *args) if widget_proxy.has_attribute?(attribute_name, *args)
127
+ end
128
+ end
129
+ super
130
+ end
131
+
132
+ private
133
+
134
+ def build_checkboxes
135
+ current_selection = selection
136
+ @composites.to_a.each(&:dispose)
137
+ @checkboxes = []
138
+ @labels = []
139
+ @composites = []
140
+ items.each do |item|
141
+ body_root.content {
142
+ @composites << composite {
143
+ grid_layout(2, false) {
144
+ margin_width 0
145
+ margin_height 0
146
+ horizontal_spacing 0
147
+ vertical_spacing 0
148
+ }
149
+ checkboxes << checkbox { |checkbox_proxy|
150
+ on_widget_selected {
151
+ self.selection_indices = checkboxes.each_with_index.map {|cb, i| i if cb.selection}.to_a.compact
152
+ }
153
+ }
154
+ labels << label { |label_proxy|
155
+ layout_data :fill, :center, true, false
156
+ text item
157
+ on_mouse_up { |event|
158
+ found_text = labels.each_with_index.detect {|l, i| event.widget == l.swt_widget}[0]&.text
159
+ selection_values = self.selection
160
+ if selection_values.include?(found_text)
161
+ selection_values.delete(found_text)
162
+ else
163
+ selection_values << found_text
164
+ end
165
+ self.selection = selection_values
166
+ }
167
+ }
168
+ }
169
+ }
170
+ end
171
+ observation_requests.to_a.each do |observation_request, block|
172
+ delegate_observation_request_to_checkboxes(observation_request, &block)
173
+ end
174
+ self.selection = current_selection
175
+ end
176
+ end
177
+
178
+ CheckGroup = CheckboxGroup
179
+ end
180
+ end
181
+ end