The extensible-data package
Extensible lists: Add to a list at compile-time in many modules, which do not necessarily know each other, and then collect it into a single list in a module depending on all of them (possibly indirectly).
Extensible products: It is a record in which new fields can be added anywhere including in different modules; dependent defaults are supported, so it is still possible to make a value of such a type.
Extensible sums: Type with choices; new choices can be added anywhere including in other modules (which do not need to know each other). The operations on them are also freely extensible in the similar way.
Extensible trees: You can make a tree out of types, and have a value at each node. New nodes can be added anywhere if you have access to the node which will become the new node's parent.
|Versions||0.1, 0.1.0.1, 0.1.0.2, 0.1.0.3, 0.1.0.4|
|Dependencies||base (>=4.3 && <5.0), data-lens (>=2.0.1 && <2.2), hashable (>=22.214.171.124 && <1.2), template-haskell (>=126.96.36.199 && <2.8), unordered-containers (>=0.1.4.6 && <0.2) [details]|
|Uploaded||Fri Feb 17 19:25:25 UTC 2012 by AaronBlack|
|Downloads||1044 total (9 in the last 30 days)|
|Status||Docs uploaded by user
Build status unknown [no reports yet]
For package maintainers and hackage trustees