Difference between revisions of "Reactive-banana"

From HaskellWiki
Jump to navigation Jump to search
(38 intermediate revisions by 4 users not shown)
Line 1: Line 1:
 
== What is it? ==
 
== What is it? ==
   
  +
<div style="float:left;">
Reactive-banana is a small library for [[Functional Reactive Programming]] (FRP).
 
  +
[[Image:Reactive-Banana-banana.png|Reactive banana displaying trigger-happy <code>Behavior</code>.]]</div>
 
''Reactive-banana'' is a practical library for [[Functional Reactive Programming]] (FRP).
   
  +
Support the project with a small donation: [http://flattr.com/thing/384682/reactive-banana http://api.flattr.com/button/flattr-badge-large.png]
The goal is to create a solid foundation for anything FRP-related.
 
  +
* Users can finally start experimenting with '''graphical user interfaces''' based on FRP since the library can be hooked into ''any'' existing event-based framework like [[wxHaskell]] or [[Gtk2Hs]], and will provide ample documentation.
 
  +
FRP offers an elegant and concise way to express interactive programs such as graphical user interfaces, animations, [[Reactive-balsa|computer music]] or robot controllers. It promises to avoid the spaghetti code that is all too common in traditional approaches to GUI programming.
* Programmers interested in implementing FRP will have a '''reference''' for a '''simple semantics''' with a working implementation.
 
  +
* It features an '''efficient implementation'''. No more spooky time leaks, predicting space & time usage should be straightforward.
 
 
The goal of the library is to provide a solid foundation.
  +
* Writing '''graphical user interfaces''' with FRP is made easy. The library can be hooked into ''any'' existing event-based framework like [[wxHaskell]] or [[Gtk2Hs]]. A plethora of [[#documentation|example code]] helps with getting started. You can mix FRP and imperative style. If you don't know how to express functionality in terms of FRP, just temporarily switch back to the imperative style.
 
* Programmers interested in the implementation of FRP will have a '''reference''' for a '''simple semantics''' with a working implementation. The library stays close to the semantics pioneered by Conal Elliott.
 
* The library features an '''efficient implementation'''. No more spooky time leaks, predicting space & time usage should be straightforward.
   
 
[[#feedback|Feedback]] is welcome, I want to hear from you!
 
[[#feedback|Feedback]] is welcome, I want to hear from you!
Line 12: Line 18:
 
== Status ==
 
== Status ==
   
  +
Current development focuses on dynamic event switching. Examples from game programming and computer music are planned.
Current development focuses on providing tutorials, documentation and examples for the library. Furthermore, the author is writing an [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/ example application] to flesh out the FRP approach to GUI programming.
 
   
  +
* 02 August 2013: Initial release of reactive-banana-threepenny. Binds to the threepenny-gui GUI library.
; 22 June 2011 : reactive-banana 0.3.0.0 released
 
; 28 April 2011 : reactive-banana 0.2.0.0 released
+
* 26 August 2012: reactive-banana 0.7.0.0 released. Features dynamic event switching.
  +
* 15 May 2012: reactive-banana 0.6.0.0 released.
  +
* 25 March 2012: reactive-banana 0.5.0.0 released.
  +
* 24 October 2011: reactive-banana 0.4.3.0 released.
  +
* 26 September 2011: Added some more examples, reactive-banana 0.4.2.0 released.
  +
* 14 July 2011: Implemented many examples, reactive-banana 0.4.1.0 released.
 
* 22 June 2011: reactive-banana 0.3.0.0 released
  +
* 28 April 2011: reactive-banana 0.2.0.0 released
  +
  +
== Fake Testimonials ==
  +
  +
"In the programming-language world, one rule of survival is simple: dance or die. This library makes dancing easy." – ''Simon Banana Jones''
  +
  +
"About the use of language: it is impossible to sharpen a pencil with a blunt axe. You should try reactive-banana instead." — ''Event Dijkstra''
  +
  +
"When I need a <code>bullet</code> event, I can just trigger it." — ''Billy the Reactive Banana''
  +
  +
"This should be in a museum!" — ''Banana Jones''
  +
  +
"Hey Mister! Why not use reactive-banana as a smartphone app to brush your teeth?" — ''Tommy "Banana" Johnson''
   
 
== Releases and Resources ==
 
== Releases and Resources ==
 
* Download on Hackage
 
* Download on Hackage
** [http://hackage.haskell.org/package/reactive-banana reactive-banana] - the FRP library itself
+
** {{HackagePackage|id=reactive-banana}} - the FRP library itself
** [http://hackage.haskell.org/package/reactive-banana-wx reactive-banana-wx] - binding to the [[wxHaskell]] GUI library
+
** {{HackagePackage|id=reactive-banana-threepenny}} - binding to the {{HackagePackage|id=threepenny-gui}} GUI library
  +
** {{HackagePackage|id=reactive-banana-wx}} - binding to the [[wxHaskell]] GUI library
* '''Documentation'''
 
  +
* <span id="documentation">Documentation</span>
** [http://hackage.haskell.org/package/reactive-banana API documentation]
 
  +
** [[FRP explanation using reactive-banana | Tutorial: Explanation of FRP using reactive-banana]]
** [[/Examples/]]
 
 
** [http://hackage.haskell.org/package/reactive-banana API reference]
 
** '''[[/Examples/]]'''
 
** [http://apfelmus.nfshost.com/blog.html#functional-reactive-programming-frp Developer Blog]
 
** [http://apfelmus.nfshost.com/blog.html#functional-reactive-programming-frp Developer Blog]
 
* <span id="feedback">Feedback</span> and Contact
 
* <span id="feedback">Feedback</span> and Contact
 
** Maintainer: [http://apfelmus.nfshost.com/ Heinrich Apfelmus] <apfelmus at quantentunnel de>
 
** Maintainer: [http://apfelmus.nfshost.com/ Heinrich Apfelmus] <apfelmus at quantentunnel de>
** [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/issues?sort=created&direction=desc&state=open Issue Tracker]
+
** Bugs and feature requests? [https://github.com/HeinrichApfelmus/reactive-banana/issues?sort=created&direction=desc&state=open Issue Tracker!]
  +
** Questions? [http://stackoverflow.com/questions/ask?tags=reactive-programming+haskell+frp+reactive-banana Ask on StackOverflow!]
 
* Source code on github
 
* Source code on github
** [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/tree/master/reactive-banana reactive-banana]
+
** [https://github.com/HeinrichApfelmus/reactive-banana/tree/develop/reactive-banana reactive-banana] development branch
** [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/tree/master/reactive-banana-wx reactive-banana-wx]
+
** [https://github.com/HeinrichApfelmus/reactive-banana/tree/master/reactive-banana-threepenny reactive-banana-threepenny] master branch
** [https://github.com/HeinrichApfelmus/Haskell-BlackBoard/ BlackBoard] - eat my own dogfood application
 
 
   
 
== External Links ==
 
== External Links ==
  +
* [https://github.com/bernstein/breakout breakout], a small game
No external links yet.
 
   
   
Line 43: Line 69:
 
[[Category:wxHaskell]]
 
[[Category:wxHaskell]]
 
[[Category:Packages]]
 
[[Category:Packages]]
  +
[[Category:Robotics]]

Revision as of 09:25, 2 August 2013

What is it?

Reactive banana displaying trigger-happy Behavior.

Reactive-banana is a practical library for Functional Reactive Programming (FRP).

Support the project with a small donation: flattr-badge-large.png

FRP offers an elegant and concise way to express interactive programs such as graphical user interfaces, animations, computer music or robot controllers. It promises to avoid the spaghetti code that is all too common in traditional approaches to GUI programming.

The goal of the library is to provide a solid foundation.

  • Writing graphical user interfaces with FRP is made easy. The library can be hooked into any existing event-based framework like wxHaskell or Gtk2Hs. A plethora of example code helps with getting started. You can mix FRP and imperative style. If you don't know how to express functionality in terms of FRP, just temporarily switch back to the imperative style.
  • Programmers interested in the implementation of FRP will have a reference for a simple semantics with a working implementation. The library stays close to the semantics pioneered by Conal Elliott.
  • The library features an efficient implementation. No more spooky time leaks, predicting space & time usage should be straightforward.

Feedback is welcome, I want to hear from you!

Status

Current development focuses on dynamic event switching. Examples from game programming and computer music are planned.

  • 02 August 2013: Initial release of reactive-banana-threepenny. Binds to the threepenny-gui GUI library.
  • 26 August 2012: reactive-banana 0.7.0.0 released. Features dynamic event switching.
  • 15 May 2012: reactive-banana 0.6.0.0 released.
  • 25 March 2012: reactive-banana 0.5.0.0 released.
  • 24 October 2011: reactive-banana 0.4.3.0 released.
  • 26 September 2011: Added some more examples, reactive-banana 0.4.2.0 released.
  • 14 July 2011: Implemented many examples, reactive-banana 0.4.1.0 released.
  • 22 June 2011: reactive-banana 0.3.0.0 released
  • 28 April 2011: reactive-banana 0.2.0.0 released

Fake Testimonials

"In the programming-language world, one rule of survival is simple: dance or die. This library makes dancing easy." – Simon Banana Jones

"About the use of language: it is impossible to sharpen a pencil with a blunt axe. You should try reactive-banana instead." — Event Dijkstra

"When I need a bullet event, I can just trigger it." — Billy the Reactive Banana

"This should be in a museum!" — Banana Jones

"Hey Mister! Why not use reactive-banana as a smartphone app to brush your teeth?" — Tommy "Banana" Johnson

Releases and Resources

External Links