Skip to content

raydac/go-gwt-example

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

52 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

golang-gwt

Introduction

Golang doesn't provide any GUI out of the box, there are some 3rd party libraries for that but unfortunately not many of them work in real cross-platform manner or provide rich set of features and nice GUI. Fortunately today we have WEB as modern cross-platform UI technology which provides even more than we need.

In 2010 I took a part in a big project which strongly used GWT for frontend part and I decided that it would be interesting to try to organize GUI for a golang application through GWT which would be used as frontend (also it would make possibility to use powerful GWT extensions like GWT-Ext or Smart-GWT). Of course it sounds very heterogenic and usually such projects make pain (especially in Golang which doesn't provide strong possibilities for build and dependency management out of the box) but because GWT is a Java based technology then it is possible to use Maven to build both Java part and Golang part in the same project without problems (Golang part will be built through mvn-golang plugin).

Project structure

The Project contains two parts

  • frontend part written in GWT, all stuff related to the front end part is situated in the frontend folder
  • backend part written in Golang, al stuff related to the backend part is situated in the backend folder

It is not just regular web service because:

  • it starts on 127.0.0.1 local address
  • it doesn't have fixed port number, just after start it looks for free port and open default web browser by providing formed page URL
  • it will be closed in 5 seconds after GUI part in browser is closed by user

Frontend part

The Part doesn't have any magic and implemented as a single web age aplication which shows text field and button. If enter some text into the text field and then press the send button then the entered text will be sent to the Golang part and the returned result will be shown just under the text field. Also the timer label situated just under the text feld shows the current time gotten from the Goang part. The Compiled part takes a bit more space tha it could be ecause I ave trned off GWT obfuscation to provide better diagnostic information. All communication with the backend part is based on GET and POST requests, there is not any web-socket use.

Backend part

It is a just simple Golang application implementing web server. Just after start it finds first free port and use it to start inside web server on local address 127.0.0.1, after that it opens the link to the inside main web page in default system browser. If it doesn't get requests from its frontend part during 5 seconds then it guesses that its frontend part has been closed and end execution.
As third party libraries I use below listed ones:

  • open-golang to open default system browser for provded URL
  • go-bindata to pack frontend static data into executable file

Requirements for build

It requires pre-installed Java SDK 1.8+ and Maven 3.0.3+ on your machine. Because the project uses mvn-golang-wrapper it will automatically download GoLang SDK.
NB! Java is needed only for build purposes! As the build result there will be just standard Golang executable file which can be delivered and started without any Java!

How to build

You can just clone the project through git clone https://github.com/raydac/go-gwt-example.git and then execute mvn command inside cloned folder (the project has default goals clean install)

Where to look for executable file?

After build you can open backend/bin folder and there will be backend-1.0.0-SNAPSHOT or backend-1.0.0-SNAPSHOT.exe executable file which is the result file. If to execute such file then default system browser will be started and frontend part will be shown.

screenshot

About

Example of GWT as frontend for Golang application

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published