glimmer-dsl-swt 0.5.5 → 0.6.3

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: '0281642708bc9fc3c57d913c1b1a33e4f9699e6999d290467bbaf02b706319cb'
4
- data.tar.gz: 9499e48b14742b2034321631edc06be69212fc0c762a13727ad70cf880d86b6f
3
+ metadata.gz: c4290c2587a5d74bdbd39df1e1459219628abd0f867df9c972ec766d1581e786
4
+ data.tar.gz: a422f8c8f1cad97b8c59f72eefdbdac2bfab5076e45b4d99bacbea063f683897
5
5
  SHA512:
6
- metadata.gz: 7ad2211fa73e076d2993e3e487547cf486c96f500406666f6e9c3a16351c87f118337478b29fea0bd469d937ae7225520fc2efb55259db94766a97313990f9cc
7
- data.tar.gz: 66312d638303de3ed1e6c100e4d4bec21c7b6e52203cfc2ef9368b2df7bb0662d08859f96be50fa4928dad10c88b112e71510c75de71f48ee818c7818c0dbbbd
6
+ metadata.gz: cfe72e5b9043ca482199ebcdb21ce5dfb3bcf5106b4adf2d1f5928d195b9ae99fbd1cd10b120ec14901052121a3cb82e5e45a203e235daaf2bd29addc6e29f60
7
+ data.tar.gz: 9f1d1bd197e61a8a462f5afc8d84466b0a595f0ab225999571d9fb22c8f00e078928a675a4474fde34c1274aaac252c4d23f7c7fcd38fea155a0cac8e6769767
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 0.5.5 (Desktop GUI)
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 0.6.3 (Desktop GUI)
2
2
  [![Gem Version](https://badge.fury.io/rb/glimmer-dsl-swt.svg)](http://badge.fury.io/rb/glimmer-dsl-swt)
3
3
  [![Travis CI](https://travis-ci.com/AndyObtiva/glimmer-dsl-swt.svg?branch=master)](https://travis-ci.com/github/AndyObtiva/glimmer-dsl-swt)
4
4
  [![Coverage Status](https://coveralls.io/repos/github/AndyObtiva/glimmer-dsl-swt/badge.svg?branch=master)](https://coveralls.io/github/AndyObtiva/glimmer-dsl-swt?branch=master)
@@ -1 +1 @@
1
- jruby-9.2.12.0
1
+ jruby-9.2.13.0
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.5.5
1
+ 0.6.3
data/bin/girb CHANGED
@@ -1,4 +1,4 @@
1
- #!/usr/bin/env ruby
1
+ #!/usr/bin/env jruby
2
2
 
3
3
  trap "SIGINT" do
4
4
  # No Op for irb
@@ -1,4 +1,4 @@
1
- #!/usr/bin/env ruby
1
+ #!/usr/bin/env jruby
2
2
 
3
3
  require_relative '../lib/glimmer/launcher'
4
4
 
Binary file
Binary file
@@ -105,7 +105,6 @@ end
105
105
  Glimmer::Config.excluded_keyword_checkers << lambda do |method_symbol, *args|
106
106
  method = method_symbol.to_s
107
107
  result = false
108
- result ||= method.start_with?('on_swt_') && is_a?(Glimmer::UI::CustomWidget) && respond_to?(method)
109
108
  result ||= method == 'dispose' && is_a?(Glimmer::UI::CustomWidget) && respond_to?(method)
110
109
  result ||= ['drag_source_proxy', 'drop_target_proxy'].include?(method) && is_a?(Glimmer::UI::CustomWidget)
111
110
  result ||= method == 'post_initialize_child'
@@ -0,0 +1,23 @@
1
+ require 'glimmer/dsl/expression'
2
+ require 'glimmer/swt/cursor_proxy'
3
+
4
+ module Glimmer
5
+ module DSL
6
+ module SWT
7
+ # cursor expression
8
+ # Note: Cannot be a static expression because it clashes with cursor property expression
9
+ class CursorExpression < Expression
10
+ def can_interpret?(parent, keyword, *args, &block)
11
+ keyword.to_s == 'cursor' and
12
+ (parent.nil? or !parent.respond_to?('cursor')) and
13
+ args.size == 1 and
14
+ (args.first.is_a?(Integer) or textual?(args.first))
15
+ end
16
+
17
+ def interpret(parent, keyword, *args, &block)
18
+ Glimmer::SWT::CursorProxy.new(*args)
19
+ end
20
+ end
21
+ end
22
+ end
23
+ end
@@ -24,6 +24,9 @@ module Glimmer
24
24
  tree_items_data_binding
25
25
  table_items_data_binding
26
26
  data_binding
27
+ cursor
28
+ font
29
+ image
27
30
  property
28
31
  block_property
29
32
  widget
@@ -0,0 +1,26 @@
1
+ require 'glimmer/dsl/expression'
2
+ require 'glimmer/dsl/top_level_expression'
3
+ require 'glimmer/swt/font_proxy'
4
+
5
+ module Glimmer
6
+ module DSL
7
+ module SWT
8
+ # font expression
9
+ # Note: Cannot be a static expression because it clashes with font property expression
10
+ class FontExpression < Expression
11
+ include TopLevelExpression
12
+
13
+ def can_interpret?(parent, keyword, *args, &block)
14
+ keyword.to_s == 'font' and
15
+ (parent.nil? || !parent.respond_to?('font')) and
16
+ args.size == 1 and
17
+ args.first.is_a?(Hash)
18
+ end
19
+
20
+ def interpret(parent, keyword, *args, &block)
21
+ Glimmer::SWT::FontProxy.new(*args)
22
+ end
23
+ end
24
+ end
25
+ end
26
+ end
@@ -0,0 +1,21 @@
1
+ require 'glimmer/dsl/expression'
2
+ require 'glimmer/swt/image_proxy'
3
+
4
+ module Glimmer
5
+ module DSL
6
+ module SWT
7
+ # image expression
8
+ # Note: Cannot be a static expression because it clashes with image property expression
9
+ class ImageExpression < Expression
10
+ def can_interpret?(parent, keyword, *args, &block)
11
+ keyword.to_s == 'image' and
12
+ (parent.nil? or !parent.respond_to?('image'))
13
+ end
14
+
15
+ def interpret(parent, keyword, *args, &block)
16
+ Glimmer::SWT::ImageProxy.new(*args)
17
+ end
18
+ end
19
+ end
20
+ end
21
+ end
@@ -16,7 +16,15 @@ module Glimmer
16
16
 
17
17
  def interpret(parent, keyword, *args, &block)
18
18
  potential_parent = args.first
19
- parent = args.shift if potential_parent.is_a?(Shell) || (potential_parent.respond_to?(:swt_widget) && potential_parent.swt_widget.is_a?(Shell))
19
+ potential_parent = potential_parent.swt_widget if potential_parent.respond_to?(:swt_widget)
20
+ parent = nil
21
+ if potential_parent.is_a?(Shell)
22
+ args.shift
23
+ parent = potential_parent
24
+ elsif potential_parent.is_a?(Widget)
25
+ args.shift
26
+ parent = potential_parent.shell
27
+ end
20
28
  Glimmer::SWT::MessageBoxProxy.new(parent, Glimmer::SWT::SWTProxy[args])
21
29
  end
22
30
  end
@@ -17,14 +17,14 @@ module Glimmer
17
17
  end
18
18
 
19
19
  def interpret(parent, keyword, *args, &block)
20
- begin
21
- class_name = "#{keyword.camelcase(:upper)}Proxy".to_sym
22
- widget_class = Glimmer::SWT.const_get(class_name)
23
- rescue
24
- widget_class = Glimmer::SWT::WidgetProxy
25
- end
26
- widget_class.new(keyword, parent, args)
20
+ Glimmer::SWT::WidgetProxy.create(keyword, parent, args)
27
21
  end
22
+
23
+ def add_content(parent, &block)
24
+ super
25
+ parent.post_add_content
26
+ end
27
+
28
28
  end
29
29
  end
30
30
  end
@@ -13,7 +13,7 @@ module Glimmer
13
13
 
14
14
  When a task is specified, it runs via rake. Some tasks take arguments in square brackets.
15
15
 
16
- Available tasks are below (you may also lookup by adding `require 'glimmer/rake_task'` in Rakefile and running rake -T):
16
+ Available tasks are below (if you do not see any, please add `require 'glimmer/rake_task'` to Rakefile and rerun or run rake -T):
17
17
  MULTI_LINE_STRING
18
18
 
19
19
  TEXT_USAGE_SUFFIX = <<~MULTI_LINE_STRING
@@ -96,6 +96,10 @@ module Glimmer
96
96
  devmode_require = '-r puts_debuggerer '
97
97
  end
98
98
  rake_tasks = Rake.application.tasks.map(&:to_s).map {|t| t.sub('glimmer:', '')}
99
+
100
+ # handle a bash quirk with calling package[msi] while there is a "packages" directory locally (it passes package[msi] as packages)
101
+ application = 'package[msi]' if application == 'packages'
102
+
99
103
  potential_rake_task_parts = application.match(REGEX_RAKE_TASK_WITH_ARGS)
100
104
  application = potential_rake_task_parts[1]
101
105
  rake_task_args = potential_rake_task_parts[2].split(',')
@@ -110,7 +114,7 @@ module Glimmer
110
114
  end
111
115
  command = "#{env_vars_string} jruby #{jruby_options_string}#{jruby_os_specific_options} #{devmode_require}-r #{the_glimmer_lib} -S #{application}"
112
116
  puts command if jruby_options_string.to_s.include?('--debug')
113
- system command
117
+ exec command
114
118
  end
115
119
  end
116
120
  end
@@ -6,6 +6,7 @@ module Glimmer
6
6
  module Package
7
7
  class << self
8
8
  attr_accessor :javapackager_extra_args
9
+ alias jpackage_extra_args :javapackager_extra_args
9
10
 
10
11
  def clean
11
12
  require 'fileutils'
@@ -41,7 +42,16 @@ module Glimmer
41
42
  system('warble')
42
43
  end
43
44
 
44
- def native
45
+ def lock_jars
46
+ puts 'Locking gem jar-dependencies by downloading & storing in vendor/jars...'
47
+ FileUtils.mkdir_p('vendor/jars')
48
+ command = "lock_jars --vendor-dir vendor/jars"
49
+ puts command
50
+ system command
51
+ end
52
+
53
+ def native(native_type=nil, native_extra_args)
54
+ puts "Generating native executable with javapackager/jpackage..."
45
55
  require 'facets/string/titlecase'
46
56
  require 'facets/string/underscore'
47
57
  project_name = File.basename(File.expand_path('.'))
@@ -51,14 +61,28 @@ module Glimmer
51
61
  license = (File.read(license_file).strip if File.exists?(license_file) && File.file?(license_file)) rescue nil
52
62
  copyright = license.split("\n").first
53
63
  human_name = project_name.underscore.titlecase
54
- command = "javapackager -deploy -native -outdir packages -outfile \"#{project_name}\" -srcfiles \"dist/#{project_name}.jar\" -appclass JarMain -name \"#{human_name}\" -title \"#{human_name}\" -Bmac.CFBundleName=\"#{human_name}\" -Bmac.CFBundleIdentifier=\"org.#{project_name}.application.#{project_name}\" -Bmac.category=\"public.app-category.business\" -BinstalldirChooser=true -Bvendor=\"#{human_name}\" -Bwin.menuGroup=\"#{human_name}\" -BsystemWide=#{OS.mac?} "
55
- command += " -BjvmOptions=-XstartOnFirstThread " if OS.mac?
56
- command += " -BappVersion=#{version} -Bmac.CFBundleVersion=#{version} " if version
57
- command += " -srcfiles LICENSE.txt -BlicenseFile=LICENSE.txt " if license
58
- command += " -Bcopyright=\"#{copyright}\" " if copyright
64
+ icon = "package/#{OS.mac? ? 'macosx' : 'windows'}/#{human_name}.#{OS.mac? ? 'icns' : 'ico'}"
65
+ if (`javapackager`.to_s.include?('Usage: javapackager') rescue nil)
66
+ command = "javapackager -deploy -native #{native_type} -outdir packages -outfile \"#{project_name}\" -srcfiles \"dist/#{project_name}.jar\" -appclass JarMain -name \"#{human_name}\" -title \"#{human_name}\" -Bmac.CFBundleName=\"#{human_name}\" -Bmac.CFBundleIdentifier=\"org.#{project_name}.application.#{project_name}\" -Bmac.category=\"public.app-category.business\" -BinstalldirChooser=true -Bvendor=\"#{human_name}\" -Bwin.menuGroup=\"#{human_name}\" "
67
+ command += " -BsystemWide=false " if OS.windows?
68
+ command += " -BjvmOptions=-XstartOnFirstThread " if OS.mac?
69
+ command += " -BappVersion=#{version} -Bmac.CFBundleVersion=#{version} " if version
70
+ command += " -srcfiles LICENSE.txt -BlicenseFile=LICENSE.txt " if license
71
+ command += " -Bcopyright=\"#{copyright}\" " if copyright
72
+ elsif (`jpackage`.to_s.include?('Usage: jpackage') rescue nil)
73
+ command = "jpackage --type #{native_type} --dest 'packages/bundles' --input 'dist' --main-class JarMain --main-jar '#{project_name}.jar' --name '#{human_name}' --vendor '#{human_name}' --icon '#{icon}' "
74
+ command += " --win-per-user-install --win-dir-chooser --win-menu --win-menu-group '#{human_name}' " if OS.windows?
75
+ command += " --java-options '-XstartOnFirstThread' --mac-package-name '#{human_name}' --mac-package-identifier 'org.#{project_name}.application.#{project_name}' " if OS.mac?
76
+ command += " --app-version \"#{version}\" " if version
77
+ command += " --license-file LICENSE.txt " if license
78
+ command += " --copyright \"#{copyright}\" " if copyright
79
+ else
80
+ puts "Neither javapackager nor jpackage exist in your Java installation. Please ensure javapackager or jpackage is available in PATH environment variable."
81
+ return
82
+ end
59
83
  command += " #{javapackager_extra_args} " if javapackager_extra_args
60
84
  command += " #{ENV['JAVAPACKAGER_EXTRA_ARGS']} " if ENV['JAVAPACKAGER_EXTRA_ARGS']
61
- puts "Generating DMG/PKG/APP/JNLP with javapackager..."
85
+ command += " #{native_extra_args} " if native_extra_args
62
86
  puts command
63
87
  system command
64
88
  end
@@ -19,17 +19,25 @@ namespace :glimmer do
19
19
  Glimmer::Package.jar
20
20
  end
21
21
 
22
- desc 'Generate Native files (DMG/PKG/APP on the Mac, EXE on Windows, RPM/DEB on Linux)'
23
- task :native do
24
- Glimmer::Package.native
22
+ desc 'Lock JARs'
23
+ task :lock_jars do
24
+ Glimmer::Package.lock_jars
25
+ end
26
+
27
+ desc 'Generate Native files. type can be dmg/pkg on the Mac, msi/exe on Windows, and rpm/deb on Linux (type is optional)'
28
+ task :native, [:type] do |t, args|
29
+ extra_args = ARGV.partition {|arg| arg.include?('package:native')}.last.to_a.join(' ')
30
+ Glimmer::Package.native(args[:type], extra_args)
25
31
  end
26
32
  end
27
33
 
28
- desc 'Package app for distribution (generating config, jar, and native files)'
29
- task :package do
34
+ desc 'Package app for distribution (generating config, jar, and native files) (type is optional)'
35
+ task :package, [:type] do |t, args|
36
+ Rake::Task['gemspec:generate'].execute
37
+ Rake::Task['glimmer:package:lock_jars'].execute
30
38
  Rake::Task['glimmer:package:config'].execute
31
39
  Rake::Task['glimmer:package:jar'].execute
32
- Rake::Task['glimmer:package:native'].execute
40
+ Rake::Task['glimmer:package:native'].execute(args)
33
41
  end
34
42
 
35
43
 
@@ -73,24 +73,11 @@ class Scaffold
73
73
 
74
74
  # Glimmer
75
75
  dist
76
- packages
76
+ packages
77
+ vendor/jars
77
78
  MULTI_LINE_STRING
78
79
 
79
- GEMFILE_APP = <<~MULTI_LINE_STRING
80
- # frozen_string_literal: true
81
-
82
- source 'https://rubygems.org'
83
-
84
- git_source(:github) {|repo_name| "https://github.com/\#{repo_name}" }
85
-
86
- gem 'glimmer-dsl-swt', '~> #{VERSION}'
87
-
88
- group :test do
89
- gem 'rspec'
90
- end
91
- MULTI_LINE_STRING
92
-
93
- GEMFILE_GEM = <<~MULTI_LINE_STRING
80
+ GEMFILE = <<~MULTI_LINE_STRING
94
81
  # frozen_string_literal: true
95
82
 
96
83
  source 'https://rubygems.org'
@@ -101,24 +88,12 @@ class Scaffold
101
88
 
102
89
  group :development do
103
90
  gem 'rspec', '~> 3.5.0'
91
+ gem 'git-glimmer', '1.7.0'
104
92
  gem 'jeweler', '2.3.9'
105
93
  gem 'simplecov', '>= 0'
106
94
  end
107
95
  MULTI_LINE_STRING
108
96
 
109
- RAKEFILE = <<~MULTI_LINE_STRING
110
- require 'glimmer/rake_task'
111
-
112
- ## Use the following configuration if you would like to customize javapackager
113
- ## arguments for `glimmer package` command.
114
- #
115
- # Glimmer::Package.javapackager_extra_args =
116
- # " -BlicenseType=" +
117
- # " -Bmac.CFBundleIdentifier=" +
118
- # " -Bmac.category=" +
119
- # " -Bmac.signing-key-developer-id-app="
120
- MULTI_LINE_STRING
121
-
122
97
  RVM_FUNCTION = <<~MULTI_LINE_STRING
123
98
  # Load RVM into a shell session *as a function*
124
99
  if [[ -s "$HOME/.rvm/scripts/rvm" ]] ; then
@@ -135,31 +110,54 @@ class Scaffold
135
110
  MULTI_LINE_STRING
136
111
 
137
112
  def app(app_name)
138
- mkdir app_name
139
- cd app_name
113
+ gem_name = file_name(app_name)
114
+ gem_summary = human_name(app_name)
115
+ system "jruby -r git-glimmer -S jeweler --rspec --summary '#{gem_summary}' --description '#{gem_summary}' #{gem_name}"
116
+ cd gem_name
117
+ rm_rf 'lib'
140
118
  write '.gitignore', GITIGNORE
141
119
  write '.ruby-version', RUBY_VERSION
142
120
  write '.ruby-gemset', app_name
143
121
  write 'VERSION', '1.0.0'
144
122
  write 'LICENSE.txt', "Copyright (c) #{Time.now.year} #{app_name}"
145
- write 'Gemfile', GEMFILE_APP
146
- write 'Rakefile', RAKEFILE
123
+ write 'Gemfile', GEMFILE
124
+ write 'Rakefile', gem_rakefile(app_name, nil, gem_name)
147
125
  mkdir 'app'
148
126
  write "app/#{file_name(app_name)}.rb", app_main_file(app_name)
149
127
  mkdir 'app/models'
150
128
  mkdir 'app/views'
151
129
  custom_shell('AppView', current_dir_name, :app)
152
- if OS.mac?
153
- mkdir_p 'package/macosx'
154
- icon_file = "package/macosx/#{human_name(app_name)}.icns"
155
- cp File.expand_path('../../../icons/scaffold_app.icns', __FILE__), icon_file
156
- puts "Created #{current_dir_name}/#{icon_file}"
157
- end
130
+
131
+ mkdir_p 'package/windows'
132
+ icon_file = "package/windows/#{human_name(app_name)}.ico"
133
+ cp File.expand_path('../../../icons/scaffold_app.ico', __FILE__), icon_file
134
+ puts "Created #{current_dir_name}/#{icon_file}"
135
+
136
+ mkdir_p 'package/macosx'
137
+ icon_file = "package/macosx/#{human_name(app_name)}.icns"
138
+ cp File.expand_path('../../../icons/scaffold_app.icns', __FILE__), icon_file
139
+ puts "Created #{current_dir_name}/#{icon_file}"
140
+
141
+ mkdir_p 'package/linux'
142
+ icon_file = "package/linux/#{human_name(app_name)}.png"
143
+ cp File.expand_path('../../../icons/scaffold_app.png', __FILE__), icon_file
144
+ puts "Created #{current_dir_name}/#{icon_file}"
145
+
158
146
  mkdir 'bin'
159
147
  write "bin/#{file_name(app_name)}", app_bin_file(app_name)
160
- system "bash -c '#{RVM_FUNCTION}\n cd .\n bundle\n glimmer package\n'"
161
- system "open packages/bundles/#{human_name(app_name).gsub(' ', '\ ')}.app"
162
- # TODO generate rspec test suite
148
+ write 'spec/spec_helper.rb', spec_helper_file
149
+ if OS.windows?
150
+ system "bundle"
151
+ system "glimmer package[image]"
152
+ system "\"packages/bundles/#{human_name(app_name)}/#{human_name(app_name)}.exe\""
153
+ else
154
+ system "bash -c '#{RVM_FUNCTION}\n cd .\n bundle\n glimmer package\n'"
155
+ if OS.mac?
156
+ system "open packages/bundles/#{human_name(app_name).gsub(' ', '\ ')}.app"
157
+ else
158
+ system "glimmer bin/#{file_name(app_name)}"
159
+ end
160
+ end
163
161
  end
164
162
 
165
163
  def custom_shell(custom_shell_name, namespace, shell_type = nil)
@@ -179,22 +177,22 @@ class Scaffold
179
177
  end
180
178
 
181
179
  def custom_shell_gem(custom_shell_name, namespace)
182
- return puts('Namespace is required! Usage: glimmer scaffold:custom_shell_gem[custom_shell_name,namespace]') unless `git config --get github.user`.to_s.strip == 'AndyObtiva'
183
180
  gem_name = "glimmer-cs-#{compact_name(custom_shell_name)}"
184
181
  gem_summary = "#{human_name(custom_shell_name)} - Glimmer Custom Shell"
185
182
  if namespace
186
183
  gem_name += "-#{compact_name(namespace)}"
187
184
  gem_summary += " (#{human_name(namespace)})"
188
185
  else
186
+ return puts('Namespace is required! Usage: glimmer scaffold:gem:customshell[name,namespace]') unless `git config --get github.user`.to_s.strip == 'AndyObtiva'
189
187
  namespace = 'glimmer'
190
188
  end
191
- system "jeweler --rspec --summary '#{gem_summary}' --description '#{gem_summary}' #{gem_name}"
189
+ system "jruby -r git-glimmer -S jeweler --rspec --summary '#{gem_summary}' --description '#{gem_summary}' #{gem_name}"
192
190
  cd gem_name
193
191
  write '.gitignore', GITIGNORE
194
192
  write '.ruby-version', RUBY_VERSION
195
193
  write '.ruby-gemset', gem_name
196
194
  write 'VERSION', '1.0.0'
197
- write 'Gemfile', GEMFILE_GEM
195
+ write 'Gemfile', GEMFILE
198
196
  write 'Rakefile', gem_rakefile(custom_shell_name, namespace, gem_name)
199
197
  append "lib/#{gem_name}.rb", gem_main_file(custom_shell_name, namespace)
200
198
  mkdir 'lib/views'
@@ -203,14 +201,35 @@ class Scaffold
203
201
  write "bin/#{gem_name}", gem_bin_file(gem_name, custom_shell_name, namespace)
204
202
  write "bin/#{file_name(custom_shell_name)}", gem_bin_command_file(gem_name)
205
203
  FileUtils.chmod 0755, "bin/#{file_name(custom_shell_name)}"
206
- if OS.mac?
207
- mkdir_p 'package/macosx'
208
- icon_file = "package/macosx/#{human_name(custom_shell_name)}.icns"
209
- cp File.expand_path('../../../icons/scaffold_app.icns', __FILE__), icon_file
210
- puts "Created #{current_dir_name}/#{icon_file}"
204
+ write 'spec/spec_helper.rb', spec_helper_file
205
+
206
+ mkdir_p 'package/windows'
207
+ icon_file = "package/windows/#{human_name(custom_shell_name)}.ico"
208
+ cp File.expand_path('../../../icons/scaffold_app.ico', __FILE__), icon_file
209
+ puts "Created #{current_dir_name}/#{icon_file}"
210
+
211
+ mkdir_p 'package/macosx'
212
+ icon_file = "package/macosx/#{human_name(custom_shell_name)}.icns"
213
+ cp File.expand_path('../../../icons/scaffold_app.icns', __FILE__), icon_file
214
+ puts "Created #{current_dir_name}/#{icon_file}"
215
+
216
+ mkdir_p 'package/linux'
217
+ icon_file = "package/linux/#{human_name(custom_shell_name)}.png"
218
+ cp File.expand_path('../../../icons/scaffold_app.png', __FILE__), icon_file
219
+ puts "Created #{current_dir_name}/#{icon_file}"
220
+
221
+ if OS.windows?
222
+ system "bundle"
223
+ system "glimmer package[image]"
224
+ system "\"packages/bundles/#{human_name(custom_shell_name)}/#{human_name(custom_shell_name)}.exe\""
225
+ else
226
+ system "bash -c '#{RVM_FUNCTION}\n cd .\n bundle\n glimmer package\n'"
227
+ if OS.mac?
228
+ system "open packages/bundles/#{human_name(custom_shell_name).gsub(' ', '\ ')}.app" if OS.mac?
229
+ else
230
+ system "bin/#{file_name(custom_shell_name)}"
231
+ end
211
232
  end
212
- system "bash -c '#{RVM_FUNCTION}\n cd .\n bundle\n glimmer package\n'"
213
- system "open packages/bundles/#{human_name(custom_shell_name).gsub(' ', '\ ')}.app"
214
233
  puts "Finished creating #{gem_name} Ruby gem."
215
234
  puts 'Edit Rakefile to configure gem details.'
216
235
  puts 'Run `rake` to execute specs.'
@@ -228,19 +247,23 @@ class Scaffold
228
247
  else
229
248
  namespace = 'glimmer'
230
249
  end
231
- system "jeweler --rspec --summary '#{gem_summary}' --description '#{gem_summary}' #{gem_name}"
250
+ system "jruby -r git-glimmer -S jeweler --rspec --summary '#{gem_summary}' --description '#{gem_summary}' #{gem_name}"
232
251
  cd gem_name
233
252
  write '.gitignore', GITIGNORE
234
253
  write '.ruby-version', RUBY_VERSION
235
254
  write '.ruby-gemset', gem_name
236
255
  write 'VERSION', '1.0.0'
237
- write 'Gemfile', GEMFILE_GEM
256
+ write 'Gemfile', GEMFILE
238
257
  write 'Rakefile', gem_rakefile
239
258
  write 'spec/spec_helper.rb', spec_helper_file
240
259
  append "lib/#{gem_name}.rb", gem_main_file(custom_widget_name, namespace)
241
260
  mkdir 'lib/views'
242
261
  custom_widget(custom_widget_name, namespace)
243
- system "bash -c '#{RVM_FUNCTION}\n cd .\n bundle\n'"
262
+ if OS.windows?
263
+ system "bundle"
264
+ else
265
+ system "bash -c '#{RVM_FUNCTION}\n cd .\n bundle\n'"
266
+ end
244
267
  puts "Finished creating #{gem_name} Ruby gem."
245
268
  puts 'Edit Rakefile to configure gem details.'
246
269
  puts 'Run `rake` to execute specs.'
@@ -338,7 +361,7 @@ class Scaffold
338
361
 
339
362
  def gem_bin_command_file(gem_name)
340
363
  <<~MULTI_LINE_STRING
341
- #!/usr/bin/env ruby
364
+ #!/usr/bin/env jruby
342
365
 
343
366
  require 'glimmer/launcher'
344
367
 
@@ -355,10 +378,11 @@ class Scaffold
355
378
  lines.insert(require_rake_line_index, "require 'glimmer/launcher'")
356
379
  gem_files_line_index = lines.index(lines.detect {|l| l.include?('# dependencies defined in Gemfile') })
357
380
  if custom_shell_name
358
- lines.insert(gem_files_line_index, " gem.files = Dir['VERSION', 'LICENSE.txt', 'lib/**/*.rb', 'bin/**/*']")
381
+ lines.insert(gem_files_line_index, " gem.files = Dir['VERSION', 'LICENSE.txt', 'lib/**/*', 'app/**/*', 'bin/**/*', 'vendor/**/*', 'package/**/*']")
359
382
  lines.insert(gem_files_line_index+1, " gem.executables = ['#{gem_name}', '#{file_name(custom_shell_name)}']")
383
+ lines.insert(gem_files_line_index+2, " gem.require_paths = ['vendor', 'lib', 'app']")
360
384
  else
361
- lines.insert(gem_files_line_index, " gem.files = Dir['lib/**/*.rb']")
385
+ lines.insert(gem_files_line_index, " gem.files = Dir['VERSION', 'LICENSE.txt', 'lib/**/*']")
362
386
  end
363
387
  spec_pattern_line_index = lines.index(lines.detect {|l| l.include?('spec.pattern =') })
364
388
  lines.insert(spec_pattern_line_index+1, " spec.ruby_opts = [Glimmer::Launcher.jruby_swt_options]")
@@ -383,7 +407,7 @@ class Scaffold
383
407
  content = File.read('spec/spec_helper.rb')
384
408
  lines = content.split("\n")
385
409
  require_line_index = lines.index(lines.detect {|l| l.include?(current_dir_name) })
386
- lines[require_line_index...require_line_index] = [
410
+ lines[require_line_index..require_line_index] = [
387
411
  "require 'bundler/setup'",
388
412
  'Bundler.require(:default, :development)',
389
413
  ]
@@ -412,9 +436,9 @@ class Scaffold
412
436
 
413
437
  if shell_type == :gem
414
438
  custom_shell_file_content += <<-MULTI_LINE_STRING
415
- GEM_ROOT = File.expand_path('../../../..', __FILE__)
416
- VERSION = File.read(File.join(GEM_ROOT, 'VERSION'))
417
- LICENSE = File.read(File.join(GEM_ROOT, 'LICENSE.txt'))
439
+ APP_ROOT = File.expand_path('../../../..', __FILE__)
440
+ VERSION = File.read(File.join(APP_ROOT, 'VERSION'))
441
+ LICENSE = File.read(File.join(APP_ROOT, 'LICENSE.txt'))
418
442
 
419
443
  MULTI_LINE_STRING
420
444
  end
@@ -470,6 +494,7 @@ class Scaffold
470
494
  shell {
471
495
  # Replace example content below with custom shell content
472
496
  minimum_size 320, 240
497
+ image File.join(APP_ROOT, 'package', 'windows', "#{human_name(shell_type == :gem ? custom_shell_name : current_dir_name)}.ico") if OS.windows?
473
498
  text "#{human_name(namespace)} - #{human_name(custom_shell_name)}"
474
499
  grid_layout
475
500
  label(:center) {
@@ -477,6 +502,17 @@ class Scaffold
477
502
  font height: 40
478
503
  layout_data :fill, :center, true, true
479
504
  }
505
+ menu_bar {
506
+ menu {
507
+ text '&File'
508
+ menu_item {
509
+ text '&Preferences...'
510
+ on_widget_selected {
511
+ display_preferences_dialog
512
+ }
513
+ }
514
+ }
515
+ }
480
516
  }
481
517
  }
482
518
  MULTI_LINE_STRING
@@ -0,0 +1,45 @@
1
+ require 'glimmer/error'
2
+ require 'glimmer/swt/swt_proxy'
3
+ require 'glimmer/swt/display_proxy'
4
+
5
+ module Glimmer
6
+ module SWT
7
+ # Proxy for org.eclipse.swt.graphics.Cursor
8
+ #
9
+ # Invoking `#swt_cursor` returns the SWT Cursor object wrapped by this proxy
10
+ #
11
+ # Follows the Proxy Design Pattern
12
+ class CursorProxy
13
+ 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}
14
+ ERROR_INVALID_CURSOR_STYLE = " is an invalid cursor style! Valid values are #{CURSOR_STYLES.map(&:to_s).join(", ")}"
15
+
16
+ include_package 'org.eclipse.swt.graphics'
17
+
18
+ attr_reader :swt_cursor, :cursor_style
19
+
20
+ # Builds a new CursorProxy from passed in cursor SWT style (e.g. :appstarting, :hand, or :help)
21
+ #
22
+ # Cursor SWT styles are those that begin with "CURSOR_" prefix
23
+ #
24
+ # They are expected to be passed in in short form without the prefix (but would work with the prefix too)
25
+ def initialize(cursor_style)
26
+ @cursor_style = cursor_style
27
+ @cursor_style = SWTProxy.reverse_lookup(@cursor_style).detect { |symbol| symbol.to_s.downcase.start_with?('cursor_') } if cursor_style.is_a?(Integer)
28
+ @cursor_style = @cursor_style.to_s.downcase
29
+ @cursor_style = @cursor_style.sub(/^cursor\_/, '') if @cursor_style.start_with?('cursor_')
30
+ detect_invalid_cursor_style
31
+ @swt_cursor = DisplayProxy.instance.swt_display.get_system_cursor(SWTProxy[swt_style])
32
+ end
33
+
34
+ def swt_style
35
+ @swt_style ||= @cursor_style.upcase.start_with?('CURSOR_') ? @cursor_style : "CURSOR_#{@cursor_style}"
36
+ end
37
+
38
+ private
39
+
40
+ def detect_invalid_cursor_style
41
+ raise Error, cursor_style.to_s + ERROR_INVALID_CURSOR_STYLE unless CURSOR_STYLES.include?(cursor_style.to_s.downcase.to_sym)
42
+ end
43
+ end
44
+ end
45
+ end
@@ -35,16 +35,26 @@ module Glimmer
35
35
  @swt_display = Display.new(*args)
36
36
  @swt_display.set_data('proxy', self)
37
37
  end
38
+
39
+ def content(&block)
40
+ Glimmer::DSL::Engine.add_content(self, Glimmer::DSL::SWT::DisplayExpression.new, &block)
41
+ end
38
42
 
39
43
  def method_missing(method, *args, &block)
40
- swt_display.send(method, *args, &block)
44
+ if can_handle_observation_request?(method)
45
+ handle_observation_request(method, &block)
46
+ else
47
+ swt_display.send(method, *args, &block)
48
+ end
41
49
  rescue => e
42
50
  Glimmer::Config.logger.debug {"Neither DisplayProxy nor #{swt_display.class.name} can handle the method ##{method}"}
43
51
  super
44
52
  end
45
53
 
46
54
  def respond_to?(method, *args, &block)
47
- super || swt_display.respond_to?(method, *args, &block)
55
+ super ||
56
+ can_handle_observation_request?(method) ||
57
+ swt_display.respond_to?(method, *args, &block)
48
58
  end
49
59
 
50
60
  def can_handle_observation_request?(observation_request)
@@ -61,6 +71,7 @@ module Glimmer
61
71
  end
62
72
 
63
73
  def handle_observation_request(observation_request, &block)
74
+ observation_request = observation_request.to_s
64
75
  if observation_request.start_with?('on_swt_')
65
76
  constant_name = observation_request.sub(/^on_swt_/, '')
66
77
  add_swt_event_listener(constant_name, &block)
@@ -6,11 +6,10 @@ module Glimmer
6
6
  module SWT
7
7
  # Proxy for org.eclipse.swt.graphics.Font
8
8
  #
9
- # This class is meant to be used with WidgetProxy to manipulate
10
- # an SWT widget font.
9
+ # This class can be optionally used with WidgetProxy to manipulate
10
+ # an SWT widget font (reusing its FontData but building a new Font)
11
11
  #
12
- # It is not meant to create new SWT fonts form scratch without
13
- # a widget proxy.
12
+ # Otherwise, if no WidgetProxy is passed to constructor, it builds new FontData
14
13
  #
15
14
  # Invoking `#swt_font` returns the SWT Font object wrapped by this proxy
16
15
  #
@@ -21,7 +20,7 @@ module Glimmer
21
20
 
22
21
  include_package 'org.eclipse.swt.graphics'
23
22
 
24
- attr_reader :widget_proxy, :swt_font
23
+ attr_reader :widget_proxy, :swt_font, :font_properties
25
24
 
26
25
  # Builds a new font proxy from passed in widget_proxy and font_properties hash,
27
26
  #
@@ -31,8 +30,9 @@ module Glimmer
31
30
  #
32
31
  # Style (:style value) can only be one of FontProxy::FONT_STYLES values:
33
32
  # that is :normal, :bold, or :italic
34
- def initialize(widget_proxy, font_properties)
33
+ def initialize(widget_proxy = nil, font_properties)
35
34
  @widget_proxy = widget_proxy
35
+ @font_properties = font_properties
36
36
  detect_invalid_font_property(font_properties)
37
37
  font_properties[:style] = SWTProxy[*font_properties[:style]]
38
38
  font_data_args = [:name, :height, :style].map do |font_property_name|
@@ -57,7 +57,7 @@ module Glimmer
57
57
  private
58
58
 
59
59
  def font_datum
60
- @font_datum ||= @widget_proxy.swt_widget.getFont.getFontData[0]
60
+ @font_datum ||= @widget_proxy ? @widget_proxy.swt_widget.getFont.getFontData[0] : FontData.new
61
61
  end
62
62
 
63
63
  def detect_invalid_font_property(font_properties)
@@ -8,7 +8,7 @@ module Glimmer
8
8
  class ImageProxy
9
9
  include_package 'org.eclipse.swt.graphics'
10
10
 
11
- attr_reader :jar_file_path, :image_data
11
+ attr_reader :file_path, :jar_file_path, :image_data, :swt_image
12
12
 
13
13
  # Initializes a proxy for an SWT Image object
14
14
  #
@@ -17,31 +17,24 @@ module Glimmer
17
17
  # and returns an image object.
18
18
  def initialize(*args)
19
19
  @args = args
20
- @jar_file_path = @args.first if @args.first.is_a?(String) && @args.size == 1
21
-
22
- end
23
-
24
- def swt_image
25
- unless @swt_image
26
- if @jar_file_path
27
- file_path = @jar_file_path
28
- if file_path.start_with?('uri:classloader')
29
- file_path = file_path.sub(/^uri\:classloader\:/, '').sub('//', '/') # the latter sub is needed for Mac
30
- object = java.lang.Object.new
31
- file_input_stream = object.java_class.resource_as_stream(file_path)
32
- buffered_file_input_stream = java.io.BufferedInputStream.new(file_input_stream)
33
- end
34
- @image_data = ImageData.new(buffered_file_input_stream || file_path)
35
- @swt_image = Image.new(DisplayProxy.instance.swt_display, @image_data)
36
- else
37
- @swt_image = Image.new(*@args)
20
+ @file_path = @args.first if @args.first.is_a?(String) && @args.size == 1
21
+ if @file_path
22
+ if @file_path.start_with?('uri:classloader')
23
+ @jar_file_path = @file_path
24
+ @file_path = @jar_file_path.sub(/^uri\:classloader\:/, '').sub('//', '/') # the latter sub is needed for Mac
25
+ object = java.lang.Object.new
26
+ file_input_stream = object.java_class.resource_as_stream(file_path)
27
+ buffered_file_input_stream = java.io.BufferedInputStream.new(file_input_stream)
38
28
  end
39
- end
40
- @swt_image
29
+ @image_data = ImageData.new(buffered_file_input_stream || @file_path)
30
+ @swt_image = Image.new(DisplayProxy.instance.swt_display, @image_data)
31
+ else
32
+ @swt_image = Image.new(*@args)
33
+ @image_data = @swt_image.image_data
34
+ end
41
35
  end
42
-
36
+
43
37
  def scale_to(width, height)
44
- return @swt_image if image_data.nil?
45
38
  scaled_image_data = image_data.scaledTo(width, height)
46
39
  device = swt_image.device
47
40
  swt_image.dispose
@@ -45,6 +45,8 @@ module Glimmer
45
45
  @widget_proxy = widget_proxy
46
46
  args = SWTProxy.constantify_args(args)
47
47
  @swt_layout = self.class.swt_layout_class_for(underscored_layout_name).new(*args)
48
+ @swt_layout.marginWidth = 15 if @swt_layout.respond_to?(:marginWidth)
49
+ @swt_layout.marginHeight = 15 if @swt_layout.respond_to?(:marginHeight)
48
50
  @widget_proxy.swt_widget.setLayout(@swt_layout)
49
51
  end
50
52
 
@@ -14,16 +14,22 @@ module Glimmer
14
14
  attr_reader :swt_widget
15
15
 
16
16
  def initialize(parent, style)
17
- parent = parent.swt_widget if parent.respond_to?(:swt_widget) && parent.swt_widget.is_a?(Shell)
18
- @temporary_parent = parent = Glimmer::SWT::ShellProxy.new.swt_widget if parent.nil?
19
- @swt_widget = MessageBox.new(parent, style)
17
+ if parent.nil?
18
+ @temporary_parent = parent = Glimmer::SWT::ShellProxy.new.swt_widget
19
+ end
20
+ @swt_widget = MessageBox.new(parent, style)
20
21
  end
21
22
 
22
23
  def open
23
- @swt_widget.open
24
- @temporary_parent&.dispose
24
+ @swt_widget.open.tap do |result|
25
+ @temporary_parent&.dispose
26
+ end
25
27
  end
26
28
 
29
+ def content(&block)
30
+ Glimmer::DSL::Engine.add_content(self, Glimmer::DSL::SWT::MessageBoxExpression.new, &block)
31
+ end
32
+
27
33
  # TODO refactor the following methods to put in a JavaBean mixin or somethin (perhaps contribute to OSS project too)
28
34
 
29
35
  def attribute_setter(attribute_name)
@@ -44,6 +50,18 @@ module Glimmer
44
50
 
45
51
  def get_attribute(attribute_name)
46
52
  @swt_widget.send(attribute_getter(attribute_name))
53
+ end
54
+
55
+ def method_missing(method, *args, &block)
56
+ swt_widget.send(method, *args, &block)
57
+ rescue => e
58
+ Glimmer::Config.logger.debug {"Neither MessageBoxProxy nor #{swt_widget.class.name} can handle the method ##{method}"}
59
+ super
60
+ end
61
+
62
+ def respond_to?(method, *args, &block)
63
+ super ||
64
+ swt_widget.respond_to?(method, *args, &block)
47
65
  end
48
66
  end
49
67
  end
@@ -1,21 +1,16 @@
1
1
  require 'glimmer/swt/widget_proxy'
2
+ require 'glimmer/swt/swt_proxy'
2
3
 
3
4
  module Glimmer
4
5
  module SWT
5
- class ScrolledCompositeProxy < Glimmer::SWT::WidgetProxy
6
- def initialize(underscored_widget_name, parent, args)
7
- unless args.first.is_a?(Numeric)
8
- args.unshift(:h_scroll)
9
- args.unshift(:v_scroll)
10
- end
11
- super
12
- swt_widget.expand_horizontal = true
13
- swt_widget.expand_vertical = true
14
- end
15
-
6
+ class ScrolledCompositeProxy < Glimmer::SWT::WidgetProxy
16
7
  def post_initialize_child(child)
17
8
  swt_widget.content = child.swt_widget
18
9
  end
10
+
11
+ def post_add_content
12
+ swt_widget.set_min_size(swt_widget.computeSize(SWTProxy[:default], SWTProxy[:default]))
13
+ end
19
14
  end
20
15
  end
21
16
  end
@@ -106,7 +106,17 @@ module Glimmer
106
106
  def deconstruct(integer)
107
107
  constant_source_class.constants.reduce([]) do |found, c|
108
108
  constant_value = constant_source_class.const_get(c) rescue -1
109
- is_found = constant_value.is_a?(Integer) && (constant_value & integer) == constant_value
109
+ is_found = constant_value.is_a?(Integer) && (integer & constant_value) == integer
110
+ is_found ? found += [c] : found
111
+ end
112
+ end
113
+
114
+ # Reverse engineer a style integer into a symbol
115
+ # Useful for debugging
116
+ def reverse_lookup(integer)
117
+ constant_source_class.constants.reduce([]) do |found, c|
118
+ constant_value = constant_source_class.const_get(c) rescue -1
119
+ is_found = constant_value.is_a?(Integer) && integer == constant_value
110
120
  is_found ? found += [c] : found
111
121
  end
112
122
  end
@@ -85,7 +85,55 @@ module Glimmer
85
85
  }
86
86
  table_editor_widget_proxy
87
87
  end,
88
- }
88
+ },
89
+ checkbox: {
90
+ widget_value_property: :selection,
91
+ editor_gui: lambda do |args, model, property, table_proxy|
92
+ first_time = true
93
+ table_proxy.table_editor.minimumHeight = 25
94
+ checkbox(*args) {
95
+ selection model.send(property)
96
+ focus true
97
+ on_widget_selected {
98
+ table_proxy.finish_edit!
99
+ }
100
+ on_focus_lost {
101
+ table_proxy.finish_edit!
102
+ }
103
+ on_key_pressed { |key_event|
104
+ if key_event.keyCode == swt(:cr)
105
+ table_proxy.finish_edit!
106
+ elsif key_event.keyCode == swt(:esc)
107
+ table_proxy.cancel_edit!
108
+ end
109
+ }
110
+ }
111
+ end,
112
+ },
113
+ radio: {
114
+ widget_value_property: :selection,
115
+ editor_gui: lambda do |args, model, property, table_proxy|
116
+ first_time = true
117
+ table_proxy.table_editor.minimumHeight = 25
118
+ radio(*args) {
119
+ selection model.send(property)
120
+ focus true
121
+ on_widget_selected {
122
+ table_proxy.finish_edit!
123
+ }
124
+ on_focus_lost {
125
+ table_proxy.finish_edit!
126
+ }
127
+ on_key_pressed { |key_event|
128
+ if key_event.keyCode == swt(:cr)
129
+ table_proxy.finish_edit!
130
+ elsif key_event.keyCode == swt(:esc)
131
+ table_proxy.cancel_edit!
132
+ end
133
+ }
134
+ }
135
+ end,
136
+ }
89
137
  }
90
138
  end
91
139
  end
@@ -276,7 +324,7 @@ module Glimmer
276
324
  new_value = @table_editor_widget_proxy&.swt_widget&.send(widget_value_property)
277
325
  if table_item.isDisposed
278
326
  @cancel_edit.call
279
- elsif new_value && !action_taken && !@edit_in_progress && !@cancel_in_progress
327
+ elsif !new_value.nil? && !action_taken && !@edit_in_progress && !@cancel_in_progress
280
328
  action_taken = true
281
329
  @edit_in_progress = true
282
330
  if new_value == model.send(model_editing_property)
@@ -22,21 +22,39 @@ module Glimmer
22
22
  include Packages
23
23
 
24
24
  DEFAULT_STYLES = {
25
- "text" => [:border],
26
- "table" => [:virtual, :border, :full_selection],
27
- "tree" => [:virtual, :border, :h_scroll, :v_scroll],
28
- "spinner" => [:border],
29
- "styled_text" => [:border],
30
- "list" => [:border, :v_scroll],
31
- "button" => [:push],
32
- "menu_item" => [:push],
33
- "drag_source" => [:drop_copy],
34
- "drop_target" => [:drop_copy],
25
+ "arrow" => [:arrow],
26
+ "button" => [:push],
27
+ "checkbox" => [:check],
28
+ "drag_source" => [:drop_copy],
29
+ "drop_target" => [:drop_copy],
30
+ "list" => [:border, :v_scroll],
31
+ "menu_item" => [:push],
32
+ "radio" => [:radio],
33
+ "scrolled_composite" => [:border, :h_scroll, :v_scroll],
34
+ "spinner" => [:border],
35
+ "styled_text" => [:border],
36
+ "table" => [:virtual, :border, :full_selection],
37
+ "text" => [:border],
38
+ "toggle" => [:toggle],
39
+ "tree" => [:virtual, :border, :h_scroll, :v_scroll],
35
40
  }
36
41
 
37
42
  DEFAULT_INITIALIZERS = {
38
43
  "composite" => lambda do |composite|
39
- composite.setLayout(GridLayout.new)
44
+ layout = GridLayout.new
45
+ layout.marginWidth = 15
46
+ layout.marginHeight = 15
47
+ composite.layout = layout
48
+ end,
49
+ "scrolled_composite" => lambda do |scrolled_composite|
50
+ scrolled_composite.expand_horizontal = true
51
+ scrolled_composite.expand_vertical = true
52
+ end,
53
+ "shell" => lambda do |shell|
54
+ layout = FillLayout.new
55
+ layout.marginWidth = 15
56
+ layout.marginHeight = 15
57
+ shell.layout = layout
40
58
  end,
41
59
  "table" => lambda do |table|
42
60
  table.setHeaderVisible(true)
@@ -49,19 +67,47 @@ module Glimmer
49
67
  group.setLayout(GridLayout.new)
50
68
  end,
51
69
  }
70
+
71
+ class << self
72
+ def create(keyword, parent, args)
73
+ widget_proxy_class(keyword).new(keyword, parent, args)
74
+ end
75
+
76
+ def widget_proxy_class(keyword)
77
+ begin
78
+ class_name = "#{keyword.camelcase(:upper)}Proxy".to_sym
79
+ Glimmer::SWT.const_get(class_name)
80
+ rescue
81
+ Glimmer::SWT::WidgetProxy
82
+ end
83
+ end
84
+
85
+ def underscored_widget_name(swt_widget)
86
+ swt_widget.class.name.split(/::|\./).last.underscore
87
+ end
88
+ end
52
89
 
53
- attr_reader :swt_widget, :drag_source_proxy, :drop_target_proxy, :drag_source_style, :drag_source_transfer, :drop_target_transfer
90
+ attr_reader :parent_proxy, :swt_widget, :drag_source_proxy, :drop_target_proxy, :drag_source_style, :drag_source_transfer, :drop_target_transfer
54
91
 
55
92
  # Initializes a new SWT Widget
56
93
  #
57
94
  # Styles is a comma separate list of symbols representing SWT styles in lower case
58
- def initialize(underscored_widget_name, parent, args)
59
- styles, extra_options = extract_args(underscored_widget_name, args)
60
- swt_widget_class = self.class.swt_widget_class_for(underscored_widget_name)
61
- @swt_widget = swt_widget_class.new(parent.swt_widget, style(underscored_widget_name, styles), *extra_options)
62
- @swt_widget.set_data('proxy', self)
95
+ def initialize(*init_args, swt_widget: nil)
96
+ if swt_widget.nil?
97
+ underscored_widget_name, parent, args = init_args
98
+ @parent_proxy = parent
99
+ styles, extra_options = extract_args(underscored_widget_name, args)
100
+ swt_widget_class = self.class.swt_widget_class_for(underscored_widget_name)
101
+ @swt_widget = swt_widget_class.new(@parent_proxy.swt_widget, style(underscored_widget_name, styles), *extra_options)
102
+ else
103
+ @swt_widget = swt_widget
104
+ underscored_widget_name = self.class.underscored_widget_name(@swt_widget)
105
+ parent_proxy_class = self.class.widget_proxy_class(self.class.underscored_widget_name(@swt_widget.parent))
106
+ @parent_proxy = parent_proxy_class.new(swt_widget: swt_widget.parent)
107
+ end
108
+ @swt_widget.set_data('proxy', self)
63
109
  DEFAULT_INITIALIZERS[underscored_widget_name]&.call(@swt_widget)
64
- parent.post_initialize_child(self)
110
+ @parent_proxy.post_initialize_child(self)
65
111
  end
66
112
 
67
113
  # Subclasses may override to perform post initialization work on an added child
@@ -69,6 +115,11 @@ module Glimmer
69
115
  # No Op by default
70
116
  end
71
117
 
118
+ # Subclasses may override to perform post add_content work
119
+ def post_add_content
120
+ # No Op by default
121
+ end
122
+
72
123
  def extract_args(underscored_widget_name, args)
73
124
  @arg_extractor_mapping ||= {
74
125
  'menu_item' => lambda do |args|
@@ -264,6 +315,7 @@ module Glimmer
264
315
 
265
316
  # This supports widgets in and out of basic SWT
266
317
  def self.swt_widget_class_for(underscored_widget_name)
318
+ underscored_widget_name = 'button' if %w[radio checkbox toggle arrow].include?(underscored_widget_name)
267
319
  swt_widget_name = underscored_widget_name.camelcase(:upper)
268
320
  swt_widget_class = eval(swt_widget_name)
269
321
  unless swt_widget_class.ancestors.include?(org.eclipse.swt.widgets.Widget)
@@ -607,6 +659,15 @@ module Glimmer
607
659
  value
608
660
  end
609
661
  end,
662
+ :cursor => lambda do |value|
663
+ cursor_proxy = nil
664
+ if value.is_a?(CursorProxy)
665
+ cursor_proxy = value
666
+ elsif value.is_a?(Symbol) || value.is_a?(String) || value.is_a?(Integer)
667
+ cursor_proxy = CursorProxy.new(value)
668
+ end
669
+ cursor_proxy ? cursor_proxy.swt_cursor : value
670
+ end,
610
671
  :foreground => color_converter,
611
672
  :font => lambda do |value|
612
673
  if value.is_a?(Hash)
Binary file
Binary file
Binary file
metadata CHANGED
@@ -1,21 +1,21 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: glimmer-dsl-swt
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.5
4
+ version: 0.6.3
5
5
  platform: ruby
6
6
  authors:
7
7
  - AndyMaleh
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-07-30 00:00:00.000000000 Z
11
+ date: 2020-09-01 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  requirement: !ruby/object:Gem::Requirement
15
15
  requirements:
16
16
  - - "~>"
17
17
  - !ruby/object:Gem::Version
18
- version: 0.10.1
18
+ version: 0.10.2
19
19
  name: glimmer
20
20
  type: :runtime
21
21
  prerelease: false
@@ -23,7 +23,7 @@ dependencies:
23
23
  requirements:
24
24
  - - "~>"
25
25
  - !ruby/object:Gem::Version
26
- version: 0.10.1
26
+ version: 0.10.2
27
27
  - !ruby/object:Gem::Dependency
28
28
  requirement: !ruby/object:Gem::Requirement
29
29
  requirements:
@@ -57,7 +57,7 @@ dependencies:
57
57
  requirements:
58
58
  - - "~>"
59
59
  - !ruby/object:Gem::Version
60
- version: 0.9.0
60
+ version: 0.10.0
61
61
  name: puts_debuggerer
62
62
  type: :runtime
63
63
  prerelease: false
@@ -65,7 +65,21 @@ dependencies:
65
65
  requirements:
66
66
  - - "~>"
67
67
  - !ruby/object:Gem::Version
68
- version: 0.9.0
68
+ version: 0.10.0
69
+ - !ruby/object:Gem::Dependency
70
+ requirement: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - '='
73
+ - !ruby/object:Gem::Version
74
+ version: 1.7.0
75
+ name: git-glimmer
76
+ type: :runtime
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - '='
81
+ - !ruby/object:Gem::Version
82
+ version: 1.7.0
69
83
  - !ruby/object:Gem::Dependency
70
84
  requirement: !ruby/object:Gem::Requirement
71
85
  requirements:
@@ -294,6 +308,8 @@ files:
294
308
  - bin/girb_runner.rb
295
309
  - bin/glimmer
296
310
  - icons/scaffold_app.icns
311
+ - icons/scaffold_app.ico
312
+ - icons/scaffold_app.png
297
313
  - lib/ext/glimmer.rb
298
314
  - lib/ext/glimmer/config.rb
299
315
  - lib/glimmer-dsl-swt.rb
@@ -309,6 +325,7 @@ files:
309
325
  - lib/glimmer/dsl/swt/color_expression.rb
310
326
  - lib/glimmer/dsl/swt/column_properties_expression.rb
311
327
  - lib/glimmer/dsl/swt/combo_selection_data_binding_expression.rb
328
+ - lib/glimmer/dsl/swt/cursor_expression.rb
312
329
  - lib/glimmer/dsl/swt/custom_widget_expression.rb
313
330
  - lib/glimmer/dsl/swt/data_binding_expression.rb
314
331
  - lib/glimmer/dsl/swt/dialog_expression.rb
@@ -316,6 +333,8 @@ files:
316
333
  - lib/glimmer/dsl/swt/dnd_expression.rb
317
334
  - lib/glimmer/dsl/swt/dsl.rb
318
335
  - lib/glimmer/dsl/swt/exec_expression.rb
336
+ - lib/glimmer/dsl/swt/font_expression.rb
337
+ - lib/glimmer/dsl/swt/image_expression.rb
319
338
  - lib/glimmer/dsl/swt/layout_data_expression.rb
320
339
  - lib/glimmer/dsl/swt/layout_expression.rb
321
340
  - lib/glimmer/dsl/swt/list_selection_data_binding_expression.rb
@@ -341,6 +360,7 @@ files:
341
360
  - lib/glimmer/rake_task/list.rb
342
361
  - lib/glimmer/scaffold.rb
343
362
  - lib/glimmer/swt/color_proxy.rb
363
+ - lib/glimmer/swt/cursor_proxy.rb
344
364
  - lib/glimmer/swt/display_proxy.rb
345
365
  - lib/glimmer/swt/dnd_proxy.rb
346
366
  - lib/glimmer/swt/font_proxy.rb