2010-11-19 23:14:27 +03:00
---
2013-04-13 19:02:21 +04:00
title: hledger Developer Guide
2010-11-19 23:14:27 +03:00
---
2013-04-13 19:02:21 +04:00
# Developer guide
2010-11-19 23:14:27 +03:00
2013-04-14 22:43:26 +04:00
**Quick links:**
2010-11-19 23:14:27 +03:00
2013-04-13 19:02:21 +04:00
**hledger released version**< br >
2012-03-12 00:06:50 +04:00
[release notes ](NEWS.html ),
[hledger-web demo ](http://demo.hledger.org )
< br >
[ready-to-run binaries ](DOWNLOADS.html )
< br >
2010-12-12 20:51:14 +03:00
[hledger ](http://hackage.haskell.org/package/hledger ),
2011-06-24 07:38:00 +04:00
[hledger-web ](http://hackage.haskell.org/package/hledger-web ),
2010-12-07 12:59:33 +03:00
[hledger-vty ](http://hackage.haskell.org/package/hledger-vty ),
2012-03-12 00:06:50 +04:00
[hledger-chart ](http://hackage.haskell.org/package/hledger-chart ),
[hledger-lib ](http://hackage.haskell.org/package/hledger-lib )
packages
2011-06-24 07:38:00 +04:00
2013-04-13 19:02:21 +04:00
**hledger development version**< br >
2013-04-14 22:43:26 +04:00
[Get it ](#how-to-set-up-for-development ),
2013-04-12 23:09:12 +04:00
[browse it ](http://github.com/simonmichael/hledger ),
[changes ](http://github.com/simonmichael/hledger/commits ),
2013-04-13 19:02:21 +04:00
[CHANGES! ](http://starlogs.net/#simonmichael/hledger ) (turn up your volume)
2012-03-12 00:06:50 +04:00
<!-- [hledger-web dev demo ](http://demo.hledger.org:5001 ) -->
2011-10-10 03:35:08 +04:00
< br >
2013-04-07 00:36:51 +04:00
[developer notes ](http://github.com/simonmichael/hledger/NOTES.org ),
2011-04-23 18:53:07 +04:00
[haddock coverage ](http://hledger.org/profs/haddock-coverage ),
2012-03-12 00:06:50 +04:00
[unit test coverage ](http://hledger.org/profs/coverage/hpc_index_fun.html ),
2012-06-29 21:39:37 +04:00
[benchmark ](http://hledger.org/profs/latest.bench ),
2012-03-11 22:50:29 +04:00
<!-- [profile ](http://hledger.org/profs/latest.prof ), -->
<!-- [heap ](http://hledger.org/profs/latest.ps ) -->
2012-03-12 00:06:50 +04:00
[stale dependencies ](http://packdeps.haskellers.com/feed/?needle=hledger )
reports
< br >
< script type = "text/javascript" src = "http://haskell.org/hoogle/datadir/resources/jquery-1.4.2.js" > < / script >
< script type = "text/javascript" src = "http://haskell.org/hoogle/datadir/resources/hoogle.js" > < / script >
< form action = "http://haskell.org/hoogle/" method = "get" style = "display:inline; margin:0; padding:0;" >
[browse dev API docs ](http://hledger.org/api/frames.html )
or
< input type = "hidden" name = "prefix" value = "+hledger +hledger-lib +hledger-web +hledger-vty +hledger-chart" / >
< span style = "white-space:nowrap;"
>< input type = "text" name = "hoogle" id = "hoogle" accesskey = "1" size = "30"
/>< input type = "submit" value = "search released API docs"
/>< / span >
2011-01-23 18:20:20 +03:00
< / form >
2013-04-14 22:43:26 +04:00
\
2011-01-23 18:20:20 +03:00
2012-03-12 00:06:50 +04:00
2010-12-12 20:51:14 +03:00
## How to..
2013-04-14 22:43:26 +04:00
New contributors of all levels are most welcome.
Here are some tips to help you get productive on the hledger project.
2013-04-13 19:02:21 +04:00
2013-04-14 22:43:26 +04:00
### how to suggest enhancements
2013-04-13 19:02:21 +04:00
2013-04-14 22:43:26 +04:00
Suggestions and feature requests are easy to make, less easy to
research, and hard to implement. And, alas! We don't have a team of
sleek, well-fed, idle coders standing by to implement everybody's
wishes. (Please
[help change that ](#how-to-set-up-for-hledger-development )).
2013-04-13 19:02:21 +04:00
2013-04-14 22:43:26 +04:00
Wishes *are* welcome feedback, but we don't want them to pile up and
obscure bugs and other developer priorities, so we manage them with discussion
and optionally as cards on a trello board.
The current recommendation is
2013-04-13 19:02:21 +04:00
2013-04-14 22:43:26 +04:00
1. **discuss/research first** \
Is your wish already on the [trello wishlist/planning board ](http://hledger.org/trello )
or [bug tracker ](http://hledger.org/bugs ) ?\
Perhaps discuss it on [irc ](irc://irc.freenode.net/#ledger ), the [mail list ](http://hledger.org/list ) or trello ?
2010-12-12 20:51:14 +03:00
2013-04-14 22:43:26 +04:00
2. **report wishes on trello, bugs in the bug tracker** \
Is it a problem with the released and documented functionality ? report in the [bug tracker ](http://hledger.org/bugs )\
Is it a wish ? add a card on the [trello board ](http://hledger.org/trello ), if needed
3. **don't sweat it** \
Or, do what you think best. If a wish does land in the bug tracker, it gets the WISH label.
2010-12-12 20:51:14 +03:00
### how to report problems
2013-04-08 21:25:47 +04:00
- check for related issues in the [bug tracker ](http://hledger.org/bugs ) or in the [mail list archive ](http://hledger.org/list )
2010-12-12 20:51:14 +03:00
- discuss/confirm the issue on irc or list
2013-04-08 21:25:47 +04:00
- report new issues in the bug tracker
2010-12-12 20:51:14 +03:00
<!-- - test and share problem journal snippets at paste . hledger.org -->
### how to help with testing
- review and test our documentation and web presence
- download and test the binaries on your platform
- test installing via cabal
- use the tools and test functionality, usability, browser compatibility, ui layout etc.
- check that `hledger test` reports no failures
- [run the developer tests ](#how-to-run-the-tests )
- discuss/report problems via irc/mail list/bug tracker
### how to help with bug tracking
2013-04-03 04:30:05 +04:00
- get to know the [bug tracker ](http://hledger.org/bugs ) and its contents
2010-12-12 20:51:14 +03:00
- research and update issues
2013-04-08 21:25:47 +04:00
- some convenient url shortcuts:
2013-04-03 04:30:05 +04:00
[`hledger.org/bugs` ](http://hledger.org/bugs )
[`hledger.org/bugs/new` ](http://hledger.org/bugs/new )
`hledger.org/bugs/N`
2010-12-12 20:51:14 +03:00
2013-04-14 22:43:26 +04:00
### how to set up for development
2010-12-12 20:51:14 +03:00
2012-11-17 08:36:30 +04:00
1. get an up-to-date [ghc ](http://haskell.org/ghc ), at least 7.0 and preferably 7.6
2011-08-20 19:48:27 +04:00
2. there's probably no need to install the [haskell platform ](http://haskell.org/platform ) now, but you could
3. it's probably worth getting the latest and best cabal: `cabal update; cabal install cabal-install`
2013-04-07 00:36:51 +04:00
4. ensure you have [git ](http://git-scm.com ) installed
2012-12-28 21:43:24 +04:00
5. the hledger Makefile assumes GNU Make, so on some platforms you may need to spell "make" as "gmake"
2011-08-20 19:48:27 +04:00
2010-12-12 20:51:14 +03:00
- get the hledger repo:
2013-04-07 00:36:51 +04:00
git clone git@github.com:simonmichael/hledger.git
2010-12-12 20:51:14 +03:00
cd hledger
- install packages required to build hledger and add-ons, or as many of them as possible:
cabal update
make install
2011-08-20 23:18:24 +04:00
This will also try to cabal install development builds of the hledger
executables, so ghc-pkg unregister those afterwards if you don't want
that.
2011-08-20 19:48:27 +04:00
- try building with make:
2012-12-28 21:05:21 +04:00
make bin/hledgerdev
2011-08-20 19:48:27 +04:00
This is usually quicker and simpler than fiddling with multiple cabal packages during development.
2012-12-28 21:05:21 +04:00
Note this executable will not be as optimised as the normal cabal build, and has the "dev" suffix
as a reminder of this.
2011-08-20 19:48:27 +04:00
- try auto-building with sp:
2013-04-07 00:36:51 +04:00
make auto # or autoweb
2011-08-20 19:48:27 +04:00
2012-03-12 00:16:45 +04:00
You'll need to follow the instructions to install `sp` .
2011-08-20 19:48:27 +04:00
This is how I do most hledger development. It will recompile whenever you save changes to source files.
2010-12-12 20:51:14 +03:00
2013-04-14 22:43:26 +04:00
### how to get your changes accepted
2010-12-12 20:51:14 +03:00
2013-04-07 00:36:51 +04:00
Follow the usual github workflow:
- fork the main hledger repo on github,
- git clone it to your local machine,
- git commit, after (?) pulling and merging the latest upstream changes
- git push back to github,
- open a pull request on github,
- follow up on any discussion there.
If you're new to this process, [help.github.com ](http://help.github.com ) may be useful.
2010-12-12 20:51:14 +03:00
### how to improve the documentation
- get familiar with the website and documentation online, review and test
- get familiar with the site/doc source files (see Makefile)
- set up for hledger development
- send patches with names prefixed with "doc: " (or "site: ")
### how to run the tests
- set up for hledger development
- cabal install shelltestrunner
- make test
### how to add a test
- identify what to test
- choose the test type: unit ? functional ? benchmark ?
- currently expected to pass or fail ?
- figure out where it goes
- write test, verify expected result
- get it committed
### how to fix a bug or add a feature
- research, discuss, validate the issue/feature on irc/list/bug tracker
- look for related tests, run the tests and check they are passing
- add a test ?
- develop a patch
- include any related issue numbers in the patch name, eg: "fix for blah blah (#NNN)"
- get it committed
### how to become a contributor
- after getting one or more patches committed, read and sign the [contributor list & agreement ](CONTRIBUTORS.html )
- or, [ask ](#how-to-get-help ) to be added
### how to do code review
2013-04-07 00:36:51 +04:00
- review and discuss new pull requests and commits on github
- set up for development and test the latest changes in your own repo
2010-12-12 20:51:14 +03:00
- read the existing [code docs and source ](#quick-links )
- send feedback or discuss via irc or list
### how to help with packaging
- package hledger for linux distros, macports, etc.
- develop mac/windows installers
- find and assist distro packagers/installer developers
### how to help with project management
- clarify/update goals and principles
- monitor, report on project progress and performance
- research, compare and report on successful projects, related projects
- identify collaboration opportunities
- marketing, communication, outreach
- release management, roadmap planning
2012-03-25 00:10:37 +04:00
## Project overview
2010-12-12 20:51:14 +03:00
2012-03-25 00:10:37 +04:00
A rough overview/blueprint for the hledger project.
2010-12-12 20:51:14 +03:00
### mission, principles, goals
The hledger project aims to produce:
- a practical, accessible, dependable tool for end users
- a useful library and toolbox for finance-minded haskell programmers
- a successful, time-and-money-solvent project within a thriving ecosystem of financial software projects.
### roles and activities
- newcomer/potential user
- user
- library user
- field tester
- bug wrangler
- support
- documentor
- qa
- developer
- packager
- communicator
- project manager
### documentation
- website
- user manual
- developer guide
- code documentation: haddock
- various developer reports
- developer notes outline
- blurbs: in cabal files, module headers, google project, repo message of the day..
### quality assurance
- unit tests (HUnit, make unittest)
- functional tests (shelltestrunner, make functest)
- performance tests (simplebench, make bench)
- documentation tests (make haddocktest + manual)
- ui tests (manual)
- installation tests (manual)
### code
2013-04-07 00:36:51 +04:00
- the hledger repo is hosted on github.com:
2010-12-12 20:51:14 +03:00
2013-04-07 00:36:51 +04:00
[http://github.com/simonmichael/hledger ](http://github.com/simonmichael/hledger )
You can also jump there by entering hledger.org/code or code.hledger.org .
2010-12-12 20:51:14 +03:00
<!-- ### release process -->
<!-- ### roadmap -->
<!-- ### communication and collaboration -->
<!-- ### web presence and hosting setup -->
<!-- ### finances and other resources -->
<!-- ### licensing and legal issues -->
<!-- ### contributors and credits -->
2010-11-19 23:14:27 +03:00
2010-12-12 20:51:14 +03:00
## Related projects
2010-11-19 23:14:27 +03:00
2010-12-20 19:06:20 +03:00
- I have a few older bits and pieces [here ](http://joyful.com/Ledger )
2010-12-12 20:51:14 +03:00
- John Wiegley's [ledger ](http://wiki.github.com/jwiegley/ledger ) inspired hledger.
- Tim Docker's [ledger-reports ](http://dockerz.net/repos/ledger-reports ) builds on hledger to generate
[html reports ](http://dockerz.net/software/hledger_report_sample/report.html )
2010-12-20 19:06:20 +03:00
- [beancount ](https://furius.ca/beancount/ ) is another ledger clone, in python
- h/ledger inspired Uwe Hollerbach's [umm ](http://www.korgwal.com/umm/ )
2011-05-16 19:50:23 +04:00
- [http://darcsden.com/alex/bill ](http://darcsden.com/alex/bill ), [http://darcsden.com/alex/bill-atomo ](http://darcsden.com/alex/bill-atomo ), [http://darcsden.com/alex/bill-scheme ](http://darcsden.com/alex/bill-scheme ) - a time-tracking and billing app
- [http://darcsden.com/ozamosi/debts ](http://darcsden.com/ozamosi/debts ) - Silly debt tracking webapp
- [http://darcsden.com/housetab-multi ](http://darcsden.com/dbp/housetab-multi ), [housetab.org ](http://housetab.org ) - a webapp to manage expenses between a group of friends.
2010-11-19 23:14:27 +03:00
2010-12-12 20:51:14 +03:00
<!-- <a href="https://www.google.com/analytics/reporting/?reset=1&id=15489822" accesskey="a"></a> -->