The haskades package
Autogeneration of bindings for creating BlackBerry Cascades apps with Haskell back ends.
./haskades HaskadesBinding.hs haskades_run.cpp haskades_run.h < Types.hs
Where Types.hs is a Haskell file containing a a sum type declaration named SignalToUI and another named SignalFromUI which fully specify the communication possible between the UI layer (which you write in QML) and the Haskell backend. QML code can access these signals on the app context object. Haskell code can emit signals by using the emit function exported from the generated HaskadesBinding. The emit call is threadsafe.
Text, Lazy Text, and String all end up as QString so that QML can work with them properly, and vice-versa. UTCTime becomes QDateTime. Int, Double, and () are passed through fairly directly. Other types may have support added as there is need.
A simple example lives at https://github.com/singpolyma/haskades-sample
|Versions||0.1, 0.1.1, 0.2.0, 0.2.1|
|Change log||None available|
|Dependencies||base (==4.*), bytestring, containers, errors, haskell-src, text, text-format|
|Copyright||© 2012-2013 Stephen Paul Weber|
|Author||Stephen Paul Weber <email@example.com>|
|Maintainer||Stephen Paul Weber <firstname.lastname@example.org>|
|Source repository||head: git clone git://github.com/singpolyma/haskades.git|
|Uploaded||Thu Jul 4 00:26:08 UTC 2013 by StephenWeber|
|Downloads||496 total (22 in last 30 days)|
|Status||Docs not available [build log]|
Successful builds reported [all 1 reports]
For package maintainers and hackage trustees