This page provides a list of missing and found libraries for solving common real world programmer tasks.
If you think there should be a library for some common task, add it to this page, and someone may well step up and write it. If you know of a library to solve an open problem domain, link to it.
Another option is the new Haskell Proposals reddit, which allows voting and commenting on each new project idea.
The first place to look is the full libraries list.
- 1 Missing libraries (by problem domain)
- 2 Could be improved
- 3 Existing libraries (by problem domain)
- 4 Libraries to package
- 5 C libraries
Missing libraries (by problem domain)
A functional IMAP library would be nice, particularly one that can be used in conjunction with encryption and authentication. References have been found to a SoC project although it appears to be derelict.
Stuff to compute bessel functions, struve H1 etc.
It will be great to have a client for the open source protocol AMQ (http://en.wikipedia.org/wiki/Advanced_Message_Queuing_Protocol). This is a new transport protocol, solving problems currently addressed by Java Messaging Service, MQ, Tibco RV, etc. Financial companies such infrastructure to distribute massive amounts of market data (although the protocol can be used for effeciently distributing anything)
The Streaming Text Orientated Messaging Protocol (http://stomp.codehaus.org/) is a messaging protocol supported by a good number of languages and message brokers. While not high-performance like AMQP it is apparently near trivial to implement and interact with.
Many darcs users have requested an interface to darcs as a C library. Creating this library would involve deciding on the details of the API and generating the bindings using the Haskell FFI. Designing the API is mostly done for you by following the structure of the darcs source code and how the existing commands interface with the core of darcs.
OpenID Relying Party (Consumer) library
A library allowing (web) applications to authenticate users with an OpenID would be great. WikiPedia has a good description of what is expected from the relying party.
Could be improved
Problems with existing solutions, that could be improved.
- Harpy lacks support for x86-64 - supporting both x86 and x86-64 would be a boon.
- The core HTTP libraries need a lot of work. There is the beginnings of a useful library there, but many http codes are not handled, and there should be simple 'get' and 'head' functionality. Also there should be common data structures for HTTP Response and Request, that are shared between HTTP servers (HWS and offsprings) and HTTP clients.
- Binary serialisation support should be ported to bytestring, and added to the extralibs bundle
- (Support for wider Word values in bytestring -> solved by Storable Vector.)
- Adding bytestring support to Parsec.
- Simple process forking/popen, of type
String -> IO String, is needed (the implementation should be in base)
If you have code that improves on something in the base libraries, you might consider submitting it to the libraries process, so it can appear in the standard libraries.
Existing libraries (by problem domain)
See GUI libraries
High performance string IO
See String libraries
See Binary IO
See Compressing data
See Crypto libraries
See Web frameworks
See XML handling
Libraries to package
Several cool libraries are out there, not yet in hackage / cabal format. Some on the hitlist , that would be great to package up would be:
- probabilistic monads
- one of the libcurl bindings, either http://code.haskell.org/curl/ or better yet the SoC work at http://google-summer-of-code-2007-haskell.googlecode.com/files/Mieczyslaw_Bak.tar.gz.
C libraries are often very popular, and cheap to bind to. A good task would be to just write bindings to C libraries, sorted by popularity.
Possible library rankings are provided by: