Glimmer DSL for SWT 4.18.4.8
JRuby Desktop Development GUI Framework
Contributors Wanted! (Submit a Glimmer App Sample to Get Started)
Glimmer DSL for SWT is a native-GUI cross-platform desktop development library written in JRuby, an OS-threaded faster JVM version of Ruby. Glimmer's main innovation is a declarative Ruby DSL that enables productive and efficient authoring of desktop application user-interfaces by relying on the robust Eclipse SWT library. Glimmer additionally innovates by having built-in data-binding support, which greatly facilitates synchronizing the GUI with domain models, thus achieving true decoupling of object oriented components and enabling developers to solve business problems (test-first) without worrying about GUI concerns, or alternatively drive development GUI-first, and then write clean business models (test-first) afterwards. Not only does Glimmer provide a large set of GUI widgets, but it also supports drawing Canvas Graphics like Shapes and Animations. To get started quickly, Glimmer offers scaffolding options for Apps, Gems, and Custom Widgets. Glimmer also includes native-executable packaging support, sorely lacking in other libraries, thus enabling the delivery of desktop apps written in Ruby as truly native DMG/PKG/APP files on the Mac + App Store, MSI/EXE files on Windows, and Gem Packaged Shell Scripts on Linux.
Glimmer receives two updates per month. You can trust Glimmer with your Ruby desktop GUI development needs. Please make Glimmer even better by providing feedback and contributing when possible.
Gem version numbers are in sync with the SWT library versions. The first two digits represent the SWT version number. The last two digits represent the minor and patch versions of Glimmer DSL for SWT.
Glimmer DSL for SWT versions 4.18.x.y come with SWT 4.18, which was released on December 2, 2020.
Featured in JRuby Cookbook and Chalmers/Gothenburg University Software Engineering Master's Lecture Material
Glimmer DSL gems:
- glimmer-dsl-swt: Glimmer DSL for SWT (JRuby Desktop Development GUI Framework)
- glimmer-dsl-opal: Glimmer DSL for Opal (Pure Ruby Web GUI and Auto-Webifier of Desktop Apps)
- glimmer-dsl-xml: Glimmer DSL for XML (& HTML)
- glimmer-dsl-css: Glimmer DSL for CSS
- glimmer-dsl-tk: Glimmer DSL for Tk (MRI Ruby Desktop Development GUI Library)
Examples
Hello, World! Sample
Glimmer GUI DSL code (from samples/hello/hello_world.rb):
include Glimmer
shell {
text "Glimmer"
label {
text "Hello, World!"
}
}.open
Run via glimmer samples
or directly:
glimmer samples/hello/hello_world.rb
Glimmer app:
Learn more about Hello, World!.
Hello, Table! Sample
Glimmer GUI DSL code (from samples/hello/hello_table.rb):
# ... model code precedes
shell {
grid_layout
text 'Hello, Table!'
background_image File.('hello_table/baseball_park.png', __dir__)
label {
layout_data :center, :center, true, false
text 'BASEBALL PLAYOFF SCHEDULE'
background :transparent
foreground rgb(94, 107, 103)
font name: 'Optima', height: 38, style: :bold
}
combo(:read_only) {
layout_data :center, :center, true, false
selection bind(BaseballGame, :playoff_type)
font height: 14
}
table(:editable) { |table_proxy|
layout_data :fill, :fill, true, true
table_column {
text 'Game Date'
width 150
sort_property :date # ensure sorting by real date value (not `game_date` string specified in items below)
editor :date_drop_down, property: :date_time
}
table_column {
text 'Game Time'
width 150
sort_property :time # ensure sorting by real time value (not `game_time` string specified in items below)
editor :time, property: :date_time
}
table_column {
text 'Ballpark'
width 180
editor :none
}
table_column {
text 'Home Team'
width 150
editor :combo, :read_only # read_only is simply an SWT style passed to combo widget
}
table_column {
text 'Away Team'
width 150
editor :combo, :read_only # read_only is simply an SWT style passed to combo widget
}
table_column {
text 'Promotion'
width 150
# default text editor is used here
}
# Data-bind table items (rows) to a model collection property, specifying column properties ordering per nested model
items bind(BaseballGame, :schedule), column_properties(:game_date, :game_time, :ballpark, :home_team, :away_team, :promotion)
# Data-bind table selection
selection bind(BaseballGame, :selected_game)
# Default initial sort property
sort_property :date
# Sort by these additional properties after handling sort by the column the user clicked
additional_sort_properties :date, :time, :home_team, :away_team, :ballpark, :promotion
{
{
text 'Book'
{
book_selected_game
}
}
}
}
{
text 'Book Selected Game'
layout_data :center, :center, true, false
font height: 14
enabled bind(BaseballGame, :selected_game)
{
book_selected_game
}
}
}.open
# ...
Run via glimmer samples
or directly:
glimmer samples/hello/hello_table.rb
Glimmer App:
Learn more about Hello, Table!.
Tetris
Glimmer GUI DSL code (from samples/elaborate/tetris.rb):
# ... more code resides in other files (navigate sample files to learn more)
shell(:no_resize) {
grid_layout {
num_columns 2
make_columns_equal_width false
margin_width 0
margin_height 0
horizontal_spacing 0
}
text 'Glimmer Tetris'
minimum_size 475, 500
image tetris_icon
(game: game)
playfield(game_playfield: game.playfield, playfield_width: playfield_width, playfield_height: playfield_height, block_size: BLOCK_SIZE)
score_lane(game: game, block_size: BLOCK_SIZE) {
layout_data(:fill, :fill, true, true)
}
}
# ...
Run via glimmer samples
or directly:
glimmer samples/elaborate/tetris.rb
Glimmer app:
Desktop Apps Built with Glimmer DSL for SWT
Are We There Yet? - Small Project Tracking App
Math Bowling - Elementary Level Math Game Featuring Bowling Rules
Note: I offer Glimmer DSL for SWT as a free and open-source Ruby Gem that represents my interests in Ruby Programming, Desktop GUI application development with SWT, Object Oriented Design, Design Patterns, and Software Architecture. Additionally, I am sharing my professional experience and expertise in Eclipse SWT given that I am an EclipseCon/EclipseWorld presenter and have built professional applications in SWT/JFace/RCP for Obtiva and the Pampered Chef in the past. This is also done in the hopes that it would indirectly bring me work in a field I am extremely passionate about. That said, please keep in mind that I myself am learning topics in Software Engineering too everyday, including newer editions of SWT and JRuby, which seem to pop up every quarter. If you see anything that needs to be improved, please do not hesitate to contact me on Gitter or submit Issues/Pull-Requests.
Table of contents
- Glimmer (JRuby Desktop Development GUI Framework)
- Table of contents
- Background
- Software Architecture
- Platform Support
- Pre-requisites
- Setup
- Glimmer Command
- Girb (Glimmer irb) Command
- Glimmer GUI DSL Syntax
- Glimmer Configuration
- Glimmer Style Guide
- Samples
- In Production
- Packaging & Distribution
- App Updates
- Glimmer Supporting Libraries
- Glimmer Process
- Resources
- Help
- Feature Suggestions
- Change Log
- Contributing
- Contributors
- Hire Me
- License
Background
Ruby is a dynamically-typed object-oriented language, which provides great productivity gains due to its powerful expressive syntax and dynamic nature. While it is proven by the Ruby on Rails framework for web development, it currently lacks a robust platform-independent framework for building desktop applications. Given that Java libraries can now be utilized in Ruby code through JRuby, Eclipse technologies, such as SWT, JFace, and RCP can help fill the gap of desktop application development with Ruby.
Software Architecture
There are several requirements for building enterprise-level/consumer-level desktop GUI applications:
- Cross-Platform Support (Mac, Windows, Linux) without compilation/recompilation
- OS Native Look & Feel
- High Performance
- Productivity
- Maintainability
- Extensibility
- Native Executable Packaging
- Multi-Threading / Parallel Programming
- Arbitrary Graphics Painting
- Audio Support
Glimmer provides cross-platform support that does not require Ruby compilation (like Tk does), thanks to JRuby, a JVM (Java Virtual Machine) faster OS-threaded version of Ruby.
Glimmer leverages SWT (Standard Widget Toolkit), which provides cross-platform widgets that automatically use the native GUI libraries under each operating system, such as Win32 on Windows, Cocoa on Mac, and GTK on Linux.
Furthermore, what is special about SWT regarding "High Performance" is that it does all the GUI painting natively outside of Java, thus producing GUI that runs at maximum performance even in Ruby. As such, you do not need to worry about Ruby dynamic typing getting in the way of GUI performance. It has ZERO effect on it and since SWT supports making asynchronous calls for GUI rendering, you could avoid blocking the GUI completely with any computations happening in Ruby no matter how complex, thus never affecting the responsiveness of GUI of applications while taking full advantage of the productivity benefits of Ruby dynamic typing.
Glimmer takes this further by providing a very programmer friendly DSL (Domain Specific Language) that visually maps lightweight Ruby syntax to the containment hierarchy of GUI widgets (meaning Ruby blocks nested within each other map to GUI widgets nested within each other). This provides maximum productivity and maintainability.
Extensibility has never been simpler in desktop GUI application development than with Glimmer, which provides the ability to support any new custom keywords through custom widgets and custom shells (windows). Basically, you map a keyword by declaring a view class matching its name by convention with a GUI body that simply consists of reusable Glimmer GUI syntax. They can be passive views or smart views with additional logic. This provides the ultimate realization of Object Oriented Programming and micro-level MVC pattern.
Thanks to Java and JRuby, Glimmer apps can be packaged as cross-platform JAR files (with JRuby Warbler) and native executables (with Java Packager) as Mac APP/DMG/PACKAGE or Windows EXE/MSI.
The Java Virtual Machine already supports OS-native threads, so Glimmer apps can have multiple things running in parallel with no problem.
SWT supports Canvas graphics drawing, and Glimmer takes that further by provding a Canvas Shape/Transform/Animation DSL, making it very simple to decorate any existing widgets or add new widgets with a completely custom look and feel if needed for branding or entertainment (gaming) purposes.
Audio is supported via the Java Sound library in a cross-platform approach and video is supported via a Glimmer custom widget, so any Glimmer app can be enhanced with audio and video where needed.
Platform Support
Glimmer runs on the following platforms:
- Mac
- Windows
- Linux
Glimmer's GUI has the native look and feel of each operating system it runs on since it uses SWT behind the scenes, which leverages the following native libraries:
- Win32 on Windows
- Cocoa on Mac
- GTK on Linux
More info about the SWT GUI on various platforms can be found on the Eclipse WIKI and SWT FAQ:
https://wiki.eclipse.org/SWT/Devel/Gtk/Dev_guide#Win32.2FCocoa.2FGTK https://www.eclipse.org/swt/faq.php
Pre-requisites
- JDK 8u241 (1.8.0_241) (find at https://www.oracle.com/java/technologies/javase/javase8u211-later-archive-downloads.html / On Windows, ensure PATH includes Java bin directory like C:\Program Files\Java\jdk1.8.0_241\bin for javapackager to work during packaging Glimmer applications)
- JRuby 9.2.14.0 (supporting Ruby 2.5.x syntax) (get via RVM on Mac and Linux or find at https://www.jruby.org/download for Windows)
- SWT 4.18 (already included in the glimmer-dsl-swt gem)
- Git (comes with Mac and Linux. Install on Windows: https://git-scm.com/download/win )
To obtain JRuby through RVM, you may run:
rvm install jruby-9.2.14.0
Glimmer might still work on other versions of Java, JRuby and SWT, but there are no guarantees, so it is best to stick to the pre-requisites outlined above.
Setup
Please follow these instructions to make the glimmer
command available on your system via the glimmer-dsl-swt
gem.
If you intend to learn the basics of Glimmer but are not ready to build a Glimmer app yet, pick Option 1 (Direct Install).
If you intend to build a Glimmer app from scratch with scaffolding, pick Option 1 (Direct Install) as well.
Otherwise, Option 2 (Bundler) can be followed in rare cases where you want to build an app without scaffolding.
Note: if you encounter any issues, please report and then install a previous version instead from the list of Glimmer Releases (keep looking back till you find one that works). Do not be disheartened as nearly everything is only a few days of work away. That said, keep in mind that this project is free and open source, meaning provided as is, so do not expect anything, but if you help with reporting and contributing, you could speed things up or even become part of the project.
Option 1: Direct Install
(Use for Scaffolding)
Run this command to install directly:
jgem install glimmer-dsl-swt
Or this command if you want a specific version:
jgem install glimmer-dsl-swt -v 4.18.4.8
jgem
is JRuby's version of gem
command.
RVM allows running gem install
directly as an alias.
Otherwise, you may also run jruby -S gem install ...
If you are new to Glimmer and would like to continue learning the basics, you may continue to the Glimmer Command section.
Otherwise, if you are ready to build a Glimmer app, you can jump to the Glimmer Scaffolding section next.
Note: if you're using activerecord or activesupport, keep in mind that Glimmer unhooks ActiveSupport::Dependencies as it does not rely on it.
Option 2: Bundler
(Use for Manual App Creation)
Add the following to Gemfile
:
gem 'glimmer-dsl-swt', '~> 4.18.4.8'
And, then run:
jruby -S bundle install
Note: if you're using activerecord or activesupport, keep in mind that Glimmer unhooks ActiveSupport::Dependencies as it does not rely on it.
You may learn more about other Glimmer related gems (glimmer-dsl-opal
, glimmer-dsl-xml
, and glimmer-dsl-css
) at Multi-DSL Support
Glimmer Command
You can use the glimmer command to scaffold new apps, run apps & samples, package native executables, and list Glimmer community gems.
docs/reference/GLIMMER_COMMAND.md
Girb (Glimmer irb) Command
You can use girb
as an alternative to irb
when prototyping Glimmer DSL for SWT GUI DSL code.
docs/reference/GLIMMER_GIRB.md
Glimmer GUI DSL Syntax
This guide should help you get started with Glimmer DSL for SWT. For more advanced SWT details, please refer to the SWT Reference.
docs/reference/GLIMMER_GUI_DSL_SYNTAX.md
Glimmer Configuration
Glimmer configuration may be done via the Glimmer::Config
module.
docs/reference/GLIMMER_CONFIGURATION.md
Glimmer Style Guide
docs/reference/GLIMMER_STYLE_GUIDE.md
Samples
Check the samples directory in glimmer-dsl-swt for examples on how to write Glimmer applications. To run a sample, make sure to install the glimmer
gem first and then use the glimmer samples
command to run it (alternatively, you may clone the repo, follow CONTRIBUTING.md instructions, and run samples locally with development glimmer command: bin/glimmer
).
docs/reference/GLIMMER_SAMPLES.md
In Production
The following production apps have been built with Glimmer.
If you have a Glimmer app you would like referenced here, please mention in a Pull Request.
Math Bowling
Math Bowling: an educational math game for elementary level kids
Are We There Yet?
Are We There Yet?: A tool that helps you learn when your small projects will finish
Garderie Rainbow Daily Agenda
Garderie Rainbow Daily Agenda: A child nursery daily agenda reporting desktop app
Packaging & Distribution
Glimmer simplifies the process of native-executable packaging and distribution on Mac and Windows via a single glimmer package
command:
docs/reference/GLIMMER_PACKAGING_AND_DISTRIBUTION.md
App Updates
Glimmer already supports automatic (and manual) app updates via the Mac App Store for Mac apps. Simply run the glimmer package
command with the Mac App Store keys configured as per Mac Application Distribution instructions and you get automatic (and manual) app update support courtesy of the Mac App Store.
Glimmer Supporting Libraries
Here is a list of notable 3rd party gems used by Glimmer:
- juwelier: generates app gems during Glimmer Scaffolding
- logging: provides extra logging capabilities not available in Ruby Logger such as multi-threaded buffered asynchronous logging (to avoid affecting app performance) and support for multiple appenders such as stdout, syslog, and log files (the last one is needed on Windows where syslog is not supported)
- nested_inherited_jruby_include_package: makes included SWT/Java packages available to all classes/modules that mix in the Glimmer module without having to manually reimport
- os: provides OS detection capabilities (e.g.
OS.mac?
orOS.windows?
) to write cross-platform code inexpensively - puts_debuggerer: helps in troubleshooting when adding
require 'pd'
and using thepd
command instead ofputs
orp
(also#pd_inspect
or#pdi
instead of#inspect
) - rake: used to implement and execute
glimmer
commands - rake-tui: Rake Text-based User Interface. Allows navigating rake tasks with arrow keys and filtering task list by typing to quickly find an run a rake task.
- rouge: Ruby syntax highlighter used in the
code_text
Glimmer DSL for SWT custom widget leveraged by the Glimmer Meta-Sample - super_module: used to cleanly write the Glimmer::UI:CustomWidget and Glimmer::UI::CustomShell modules
- text-table: renders textual data in a textual table for the command-line interface of Glimmer
- warbler: converts a Glimmer app into a Java JAR file during packaging
Glimmer Process
Glimmer Process is the lightweight software development process used for building Glimmer libraries and Glimmer apps, which goes beyond Agile, rendering all Agile processes obsolete. Glimmer Process is simply made up of 7 guidelines to pick and choose as necessary until software development needs are satisfied.
Learn more by reading the GPG (Glimmer Process Guidelines)
Resources
- Code Master Blog
- JRuby Cookbook by Justin Edelson & Henry Liu
- InfoQ Article
- DZone Tutorial
- MountainWest RubyConf 2011 Video
- RubyConf 2008 Video
SWT Reference
https://www.eclipse.org/swt/docs.php
Here is the SWT API:
https://help.eclipse.org/2019-12/nftopic/org.eclipse.platform.doc.isv/reference/api/index.html
Here is a visual list of SWT widgets:
https://www.eclipse.org/swt/widgets/
Here is a textual list of SWT widgets:
Here is a list of SWT style bits as used in widget declaration:
https://wiki.eclipse.org/SWT_Widget_Style_Bits
Here is a SWT style bit constant reference:
Here is an SWT Drag and Drop guide:
https://www.eclipse.org/articles/Article-SWT-DND/DND-in-SWT.html
Here is an SWT Custom Widget guide:
Here is an SWT Image guide:
https://www.eclipse.org/articles/Article-SWT-images/graphics-resources.html
Here is an SWT Graphics / Canvas-Drawing guide:
https://www.eclipse.org/articles/Article-SWT-graphics/SWT_graphics.html
Here is the Nebula Project (custom widget library) homepage:
https://www.eclipse.org/nebula/
Help
Issues
You may submit issues on GitHub.
Click here to submit an issue.
Chat
Feature Suggestions
These features have been suggested. You might see them in a future version of Glimmer. You are welcome to contribute more feature suggestions.
Glimmer DSL Engine specific tasks are at:
Change Log
Also: glimmer/CHANGELOG.md
Contributing
Contributors Wanted!
If you would like to contribute to Glimmer, please study up on Glimmer and SWT, run all Glimmer samples, and build a small sample app (perhaps from this TODO list) to add to glimmer-dsl-swt Hello or Elaborate samples via a Pull Request. Once done, contact me on Chat.
You may apply for contributing to any of these Glimmer DSL gems whether you prefer to focus on the desktop or web:
- glimmer-dsl-swt: Glimmer DSL for SWT (Desktop GUI)
- glimmer-dsl-opal: Glimmer DSL for Opal (Web GUI Adapter for Desktop Apps)
- glimmer-dsl-xml: Glimmer DSL for XML (& HTML)
- glimmer-dsl-css: Glimmer DSL for CSS (Cascading Style Sheets)
Contributors
- Andy Maleh (Founder)
- Dennis Theisen (Contributor, originally in Glimmer before splitting glimmer-dsl-swt)
Click here to view contributor commits.
Hire Me
If your company would like to invest fulltime in further development of the Glimmer open-source project, hire me.
License
Copyright (c) 2007-2021 - Andy Maleh.
--
Built for Glimmer (DSL Framework).