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 +4 -4
- data/README.md +1 -1
- data/RUBY_VERSION +1 -1
- data/VERSION +1 -1
- data/bin/girb +1 -1
- data/bin/glimmer +1 -1
- data/icons/scaffold_app.ico +0 -0
- data/icons/scaffold_app.png +0 -0
- data/lib/ext/glimmer/config.rb +0 -1
- data/lib/glimmer/dsl/swt/cursor_expression.rb +23 -0
- data/lib/glimmer/dsl/swt/dsl.rb +3 -0
- data/lib/glimmer/dsl/swt/font_expression.rb +26 -0
- data/lib/glimmer/dsl/swt/image_expression.rb +21 -0
- data/lib/glimmer/dsl/swt/message_box_expression.rb +9 -1
- data/lib/glimmer/dsl/swt/widget_expression.rb +7 -7
- data/lib/glimmer/launcher.rb +6 -2
- data/lib/glimmer/package.rb +31 -7
- data/lib/glimmer/rake_task.rb +14 -6
- data/lib/glimmer/scaffold.rb +98 -62
- data/lib/glimmer/swt/cursor_proxy.rb +45 -0
- data/lib/glimmer/swt/display_proxy.rb +13 -2
- data/lib/glimmer/swt/font_proxy.rb +7 -7
- data/lib/glimmer/swt/image_proxy.rb +16 -23
- data/lib/glimmer/swt/layout_proxy.rb +2 -0
- data/lib/glimmer/swt/message_box_proxy.rb +23 -5
- data/lib/glimmer/swt/scrolled_composite_proxy.rb +6 -11
- data/lib/glimmer/swt/style_constantizable.rb +11 -1
- data/lib/glimmer/swt/table_proxy.rb +50 -2
- data/lib/glimmer/swt/widget_proxy.rb +79 -18
- data/vendor/swt/linux/swt.jar +0 -0
- data/vendor/swt/mac/swt.jar +0 -0
- data/vendor/swt/windows/swt.jar +0 -0
- metadata +26 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: c4290c2587a5d74bdbd39df1e1459219628abd0f867df9c972ec766d1581e786
|
4
|
+
data.tar.gz: a422f8c8f1cad97b8c59f72eefdbdac2bfab5076e45b4d99bacbea063f683897
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
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.
|
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)
|
data/RUBY_VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
jruby-9.2.
|
1
|
+
jruby-9.2.13.0
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.
|
1
|
+
0.6.3
|
data/bin/girb
CHANGED
data/bin/glimmer
CHANGED
Binary file
|
Binary file
|
data/lib/ext/glimmer/config.rb
CHANGED
@@ -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
|
data/lib/glimmer/dsl/swt/dsl.rb
CHANGED
@@ -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
|
-
|
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
|
-
|
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
|
data/lib/glimmer/launcher.rb
CHANGED
@@ -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
|
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
|
-
|
117
|
+
exec command
|
114
118
|
end
|
115
119
|
end
|
116
120
|
end
|
data/lib/glimmer/package.rb
CHANGED
@@ -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
|
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
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
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
|
-
|
85
|
+
command += " #{native_extra_args} " if native_extra_args
|
62
86
|
puts command
|
63
87
|
system command
|
64
88
|
end
|
data/lib/glimmer/rake_task.rb
CHANGED
@@ -19,17 +19,25 @@ namespace :glimmer do
|
|
19
19
|
Glimmer::Package.jar
|
20
20
|
end
|
21
21
|
|
22
|
-
desc '
|
23
|
-
task :
|
24
|
-
Glimmer::Package.
|
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
|
|
data/lib/glimmer/scaffold.rb
CHANGED
@@ -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
|
-
|
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
|
-
|
139
|
-
|
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',
|
146
|
-
write '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
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
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
|
-
|
161
|
-
|
162
|
-
|
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',
|
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
|
-
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
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',
|
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
|
-
|
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
|
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
|
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
|
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
|
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
|
-
|
416
|
-
VERSION = File.read(File.join(
|
417
|
-
LICENSE = File.read(File.join(
|
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
|
-
|
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 ||
|
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
|
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
|
-
#
|
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
|
-
@
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
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
|
-
|
40
|
-
|
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
|
-
|
18
|
-
|
19
|
-
|
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
|
-
|
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) && (
|
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
|
-
"
|
26
|
-
"
|
27
|
-
"
|
28
|
-
"
|
29
|
-
"
|
30
|
-
"list"
|
31
|
-
"
|
32
|
-
"
|
33
|
-
"
|
34
|
-
"
|
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
|
-
|
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(
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
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
|
-
|
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)
|
data/vendor/swt/linux/swt.jar
CHANGED
Binary file
|
data/vendor/swt/mac/swt.jar
CHANGED
Binary file
|
data/vendor/swt/windows/swt.jar
CHANGED
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.
|
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-
|
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.
|
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.
|
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.
|
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.
|
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
|