Annotations: Constructing, analyzing and destructing annotated trees

[ bsd3, generics, library ] [ Propose Tags ]

Annotations provides utility functions to make working with annotated trees easier. There are two implementations: one for working with open datatypes that explicitly make their child positions accessible through a type argument, and one for working with MultiRec datatypes.

Parser combinators make it easy to construct trees annotated with position information. For the MultiRec implementation, there is the Yield monad that allows construction of trees in postorder.

Error algebras allow destruction of trees using catamorphisms. The algebra is allowed to indicate failure in which case the error is automatically coupled with the annotation at the position at which the error occurred.

Versions 0.1, 0.1.1, 0.1.2, 0.1.3, 0.2, 0.2.1, 0.2.2
Dependencies base (>=4.1 && <4.4), mtl (>=1.1 && <2.1), multirec (>=0.4 && <0.6), parsec (>=3.0 && <3.2) [details]
License BSD-3-Clause
Copyright Copyright (c) 2008-2009 Martijn van Steenbergen
Author Martijn van Steenbergen
Maintainer martijn@van.steenbergen.nl
Category Generics
Uploaded by MartijnVanSteenbergen at Sun Feb 27 12:10:20 UTC 2011
Distributions NixOS:0.2.2
Downloads 3164 total (15 in the last 30 days)
Rating (no votes yet) [estimated by rule of succession]
Your Rating
  • λ
  • λ
  • λ
Status Docs uploaded by user
Build status unknown [no reports yet]
Hackage Matrix CI

Modules

[Index]

Downloads

Maintainer's Corner

For package maintainers and hackage trustees