diff options
-rw-r--r-- | .gitignore | 2 | ||||
-rw-r--r-- | .gitmodules | 3 | ||||
-rw-r--r-- | Makefile.am | 88 | ||||
-rw-r--r-- | NEWS | 116 | ||||
-rw-r--r-- | TODO | 1080 | ||||
-rwxr-xr-x | acprep | 1 | ||||
-rw-r--r-- | amount.cc | 1 | ||||
-rw-r--r-- | configure.in | 4 | ||||
m--------- | data | 0 | ||||
-rw-r--r-- | main.cc | 2 | ||||
-rwxr-xr-x | setup.py | 5 | ||||
-rw-r--r-- | textual.cc | 81 | ||||
-rw-r--r-- | valexpr.cc | 13 | ||||
-rw-r--r-- | valexpr.h | 1 |
14 files changed, 1145 insertions, 252 deletions
@@ -3,6 +3,7 @@ *.elc *.la *.lo +*.loT *.o *~ .deps/ @@ -20,6 +21,7 @@ /acconf.h.in /acconf.h.in~ /aclocal.m4 +/amounts.so /autom4te.cache /config.guess /config.log diff --git a/.gitmodules b/.gitmodules new file mode 100644 index 00000000..3a349c62 --- /dev/null +++ b/.gitmodules @@ -0,0 +1,3 @@ +[submodule "data"] + path = data + url = . diff --git a/Makefile.am b/Makefile.am index a9041354..e9c6070a 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,3 +1,5 @@ +EXTRA_DIST = LICENSE scripts ledger.vim sample.dat + lib_LTLIBRARIES = libamounts.la libledger.la libamounts_la_CXXFLAGS = @@ -76,6 +78,7 @@ pkginclude_HEADERS = \ option.h \ parser.h \ qif.h \ + ofx.h \ quotes.h \ reconcile.h \ report.h \ @@ -114,63 +117,62 @@ dist_lisp_LISP = ledger.el timeclock.el ###################################################################### +EXTRA_DIST += setup.py + if HAVE_BOOST_PYTHON -noinst_PROGRAMS = amounts.so +noinst_PROGRAMS = amounts.so +amounts_so_SOURCES = amounts.cc fdstream.hpp amounts.so: amounts.cc libamounts.la - CFLAGS="$(CPPFLAGS)" LDFLAGS="$(LDFLAGS) -L. -L.libs" \ - python setup.py build --build-lib=. + CFLAGS="$(CPPFLAGS) -I$(srcdir) $(libamounts_la_CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)" \ + LDFLAGS="$(LDFLAGS) -L$(top_builddir) -L$(top_builddir)/.libs" \ + ARCHFLAGS="$(ARCHFLAGS)" SRCDIR="$(srcdir)" \ + python setup.py build --build-lib=$(top_builddir) install-exec-hook: - CFLAGS="$(CPPFLAGS)" LDFLAGS="$(LDFLAGS) -L. -L.libs" \ + CFLAGS="$(CPPFLAGS) -I$(srcdir) $(libamounts_la_CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)" \ + LDFLAGS="$(LDFLAGS) -L$(top_builddir) -L$(top_builddir)/.libs" \ + ARCHFLAGS="$(ARCHFLAGS)" SRCDIR="$(srcdir)" \ python setup.py install --prefix=$(prefix) --root=$(DESTDIR)/ endif ###################################################################### -TESTS = alltests - -CXXTEST_DIR = /usr/local/cxxtest -TESTGEN = $(CXXTEST_DIR)/cxxtestgen.py -TESTSUITES = tests/*.h - -AM_CXXFLAGS = -if HAVE_EXPAT -AM_CXXFLAGS += -DHAVE_EXPAT=1 -endif -if HAVE_XMLPARSE -AM_CXXFLAGS += -DHAVE_XMLPARSE=1 -endif -if HAVE_LIBOFX -AM_CXXFLAGS += -DHAVE_LIBOFX=1 -endif -if DEBUG -AM_CXXFLAGS += -DDEBUG_LEVEL=4 -endif - -alltests.cc: $(TESTSUITES) - test -f $(TESTGEN) && python $(TESTGEN) -o $@ --error-printer $(TESTSUITES) - -alltests: alltests.cc ledger - $(CXXCOMPILE) -I$(CXXTEST_DIR) -lexpat -lgmp -lpcre -o $@ \ - alltests.cc -L. -L.libs -lamounts -lledger +TESTS = RegressionTests -runtests: alltests - LD_LIBRARY_PATH=.libs ./alltests && tests/regress && tests/regtest +DISTCLEANFILES = RegressionTests -verify: runtests - python tests/runtests.py +RegressionTests: + echo "exit 0" > $@ + chmod 755 $@ ###################################################################### -all-clean: maintainer-clean - rm -fr *~ .*~ .\#* *.html *.info *.pdf *.a *.so *.o *.lo *.la \ - *.elc *.aux *.cp *.fn *.ky *.log *.pg *.toc *.tp *.vr \ - .gdb_history gmon.out h out TAGS ledger valexpr .deps \ - .libs build AUTHORS COPYING INSTALL Makefile acconf.h \ - acconf.h.in aclocal.m4 autom4te config.guess config.sub \ - configure depcomp install-sh libtool ltconfig ltmain.sh \ - missing stamp texinfo.tex Makefile.in mkinstalldirs \ - elisp-comp elc-stamp py-compile +copy-sources: + -mkdir /tmp/ledger + rsync -av --delete $(srcdir)/.git/ /tmp/ledger/.git/ + (cd /tmp/ledger; git reset --hard HEAD; git clean -x -d -f) + +release: copy-sources + (cd /tmp/ledger; ./acprep --local && \ + make -j3 \ + CPPFLAGS="-I/usr/local/include -I/opt/local/include" \ + LDFLAGS="-L/usr/local/lib -L/opt/local/lib" \ + ARCHFLAGS="-arch i386 -arch ppc -isysroot /Developer/SDKs/MacOSX10.5.sdk" \ + CXXFLAGS="-arch i386 -arch ppc -isysroot /Developer/SDKs/MacOSX10.5.sdk" \ + LDFLAGS="$LDFLAGS -arch i386 -arch ppc -Wl,-syslibroot,/Developer/SDKs/MacOSX10.5.sdk" \ + DISTCHECK_CONFIGURE_FLAGS="--disable-dependency-tracking") + +release-distcheck: copy-sources + (cd /tmp/ledger; ./acprep --local && \ + make -j3 distcheck \ + CPPFLAGS="-I/usr/local/include -I/opt/local/include" \ + LDFLAGS="-L/usr/local/lib -L/opt/local/lib" \ + ARCHFLAGS="-arch i386 -arch ppc -isysroot /Developer/SDKs/MacOSX10.5.sdk" \ + CXXFLAGS="-arch i386 -arch ppc -isysroot /Developer/SDKs/MacOSX10.5.sdk" \ + LDFLAGS="$LDFLAGS -arch i386 -arch ppc -Wl,-syslibroot,/Developer/SDKs/MacOSX10.5.sdk" \ + DISTCHECK_CONFIGURE_FLAGS="--disable-dependency-tracking") + +# Makefile.am ends here @@ -2,121 +2,7 @@ * 2.6.1 -- Added the concept of "balance setting transactions": - - # Setting an account's balance - - You can now manually set an account's balance to whatever you want, at - any time. Here's how it might look at the beginning of your Ledger - file: - - 2008/07/27 Starting fresh - Assets:Checking = $1,000.00 - Equity:Opening Balances - - If Assets:Checking is empty, this is no different from omitting the - "=". However, if Assets:Checking did have a prior balance, the amount - of the transaction will be auto-calculated so that the final balance - of Assets:Checking is now $1,000.00. - - Let me give an example of this. Say you have this: - - 2008/07/27 Starting fresh - Assets:Checking $750.00 - Equity:Opening Balances - - 2008/07/27 Starting fresh - Assets:Checking = $1,000.00 - Equity:Adjustments - - These two entries are exactly equivalent to these two: - - 2008/07/27 Starting fresh - Assets:Checking $750.00 - Equity:Opening Balances - - 2008/07/27 Starting fresh - Assets:Checking $250.00 - Equity:Adjustments - - The use of the "=" sign here is that it sets the transaction's amount - to whatever is required to satisfy the assignment. This is the - behavior if the transaction's amount is left empty. - - # Multiple commodities - - As far as commodities go, the = sign only works if the account - balance's commodity matches the commodity of the amount after the - equals sign. However, if the account has multiple commodities, only - the matching commodity is affected. Here's what I mean: - - 2008/07/24 Opening Balance - Assets:Checking = $250.00 ; we force set it - Equity:Opening Balances - - 2008/07/24 Opening Balance - Assets:Checking = EC 250.00 ; we force set it again - Equity:Opening Balances - - This is an error, because $250.00 cannot be auto-balanced to match EC - 250.00. However: - - 2008/07/24 Opening Balance - Assets:Checking = $250.00 ; we force set it again - Assets:Checking EC 100.00 ; and add some EC's - Equity:Opening Balances - - 2008/07/24 Opening Balance - Assets:Checking = EC 250.00 ; we force set the EC's - Equity:Opening Balances - - This is *not* an error, because the latter auto-balancing transaction - only affects the EC 100.00 part of the account's balance; the $250.00 - part is left alone. - - # Checking statement balances - - When you reconcile a statement, there are typically one or more - transactions which result in a known balance. Here's how you specify - that in your Ledger data: - - 2008/07/24 Opening Balance - Assets:Checking = $100.00 - Equity:Opening Balances - - 2008/07/30 We spend money, with a known balance afterward - Expenses:Food $20.00 - Assets:Checking = $80.00 - - 2008/07/30 Again we spend money, but this time with all the info - Expenses:Food $20.00 - Assets:Checking $-20.00 = $60.00 - - 2008/07/30 This entry yield an 'unbalanced' error - Expenses:Food $20.00 - Assets:Checking $-20.00 = $30.00 - - The last entry in this set fails to balance with an unbalanced - remainder of $-10.00. Either the entry must be corrected, or you can - have Ledger deal with the remainder automatically: - - 2008/07/30 The fixed entry - Expenses:Food $20.00 - Assets:Checking $-20.00 = $30.00 - Equity:Adjustments - - # Conclusion - - This simple feature has all the utility of @check, plus auto-balancing - to match known target balances, plus the ability to guarantee that an - account which uses only one commodity does contain only that - commodity. - - This feature slows down textual parsing slightly, does not affect - speed when loading from the binary cache. - -- The rest of the changes in the version is all bug fixes (around 45 of - them). +- This version has no new features, it's all bug fixes. * 2.6.0.90 @@ -0,0 +1,1080 @@ +LEDGER -*- mode: org; fill-column: 78 -*- + +#+STARTUP: overview +#+ARCHIVE: TODO-OLD:: +#+SEQ_TODO: TODO(@) STARTED(@) WAITING(@) DELEGATED(@) | DONE(@) DEFERRED(@) CANCELLED(@) WONTFIX(@) WORKSFORME(@) INVALID(@) DUPLICATE(@) NOTE +#+TAGS: EMACS(e) FEATURE(f) DOCS(d) WEBSITE(w) BUILD(b) +#+CATEGORY: Ledger + +* TODO [#C] Merge Levin's changes into v2.6.1b + These are from http://github.com/levindu/ledger + :PROPERTIES: + :UUID: C9167249-98C3-4C7E-8076-35B81A580B38 + :END: + [2008-08-21 Thu] +* TODO [#B] Do not adjust display precision when parsing a pricing entry + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6.0.90 + :Ticket: 206 + :UUID: 7E5D2A6C-A15F-4BC8-A851-04A48E3E30F4 + :END: + [2008-07-28 Mon] +* TODO [#B] Unbalanced transactions due to rounding problems + - State "TODO" [2008-08-01 Fri 13:34] \\ + Levin <zslevin@gmail.com> writes: + > This is the result of ledger in git master branch: + :OUTPUT: +./ledger -f test.ledger -V reg HLIT +2008/06/01 BUY HLIT Assets:HLIT $750 $750 +2008/07/02 SELL HLIT Assets:HLIT $-658 0 + Assets:HLIT $658 $658 + Assets:HLIT $-658 0 + :END: + > I wonder why .xxx is vanished :) + I found some more rounding problems now that I've upgraded to 2.6.1. These + transactions balanced in version 2.5. + :DATA: +2008/06/01 BUY HLIT + Assets:HLIT 15 HLIT @ $50.00 + Assets + +2008/07/02 SELL HLIT + Assets:HLIT -15 HLIT @ $50.00 + Assets:HLIT 15 HLIT @ $43.875 + Assets:HLIT -15 HLIT @ $43.875 + Assets + :END: + :OUTPUT: +[20:30:53 vinod]:~/data $ ledger -V reg HLIT +2008/06/01 BUY HLIT Assets:HLIT $750.00 $750.00 +2008/07/02 SELL HLIT Assets:HLIT $-658.12 $0.01 + Assets:HLIT $658.13 $658.14 + Assets:HLIT $-658.12 $0.01 + :END: + So, I end up with an extra penny. I think it's because 658.125 rounds down + on one entry and rounds up on the other. + :PROPERTIES: + :Submitter: Vinod Kurup <vvkurup@gmail.com> + :Version: 2.6.1b + :Ticket: 207 + :UUID: E87DD3A5-B061-46A0-95E9-9844A6CB0443 + :END: + [2008-08-01 Fri] +* TODO [#C] Binary cache is invalidated if LEDGER_FILE is changed + The following sequence of operations seemed to trigger it: + :OUTPUT: +export LEDGER_FILE=/home/albino/temp/ledger/ledger.dat +./ledger bal rent food movies -- freddie +export LEDGER_FILE=/home/albino/temp/ledger/sample.dat +./ledger bal + :END: + :PROPERTIES: + :Submitter: albino <#ledger> + :Version: 2.6.1b + :Ticket: 211 + :UUID: C65875E1-CF5D-4923-8546-9784EB08AC9D + :END: + [2008-08-05 Tue] +* DONE [#A] -p "this month" doesn't work at all anymore + - State "DONE" [2008-07-17 Thu 18:14] \\ + This has been fixed, and represents a very major set of fixes to date + handling in general. Thanks to Nathan for hitting the nail on the head. + - State "TODO" [2008-04-05 Sat 18:57] \\ + Nathan Jones <nathanj@insightbb.com> writes: + > The patch fixes a command that I have aliased to show my last two months + > of transactions: `ledger -d 'd>=[last month]' reg checking` + > + > The problem is that the 'last month' would get parsed as 1970/1/1, so it + > would show every transaction. + :OUTPUT: +~ $ DEBUG_CLASS=ledger.config.predicates *ledger -p "this month" reg cash +Predicate: d>=[1969/12/31]&d<[1970/01/31]&/(?:cash)/ + :END: + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 38 + :Attachments: 289.patch + :UUID: 0CF00621-31C4-4E5A-B260-78B4DA8C3616 + :END: + [2008-04-04 Fri] +* DONE [#A] Cannot sort by reverse time + - State "DONE" [2008-07-19 Sat 16:52] + When I specify `--sort -d`, I get: + :OUTPUT: +~/src/ledger $ ledger -b 2008/07 --sort -d reg cash +While computing value expression: + -date + ^^^^^ +Error: Cannot negate a date/time + :END: + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6.0.90 + :Ticket: 202 + :UUID: CB97253A-581E-49D0-98D4-3BC5B0616A42 + :END: + [2008-07-17 Thu] +* DONE [#A] Core dump on simple input. + - State "DONE" [2008-07-17 Thu 17:38] + :DATA: +2008/01/03=2007/12/28 * Sell -- RHT -- RED HAT INC CA TAUX DE CHANGE .96590 + Assets:Investments:RBC-Broker:Account-RSP -4.00 RHT @ 21.14 CAD + Expenses:Financial:Commissions 9.95 USD @ .96590 CAD + Assets:Investments:RBC-Broker:Account-RSP 72.06 CAD + :END: + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 56 + :UUID: 843B6A53-C3C2-45BB-A92C-558AF6F02014 + :END: + [2008-04-07 Mon] +* DONE [#A] crash + - State "DONE" [2008-07-17 Thu 17:39] + :DATA: +2007-12-31 * Start of year / Opening balances. + Assets:Investments:HSBC-Broker 1000 USD @ 101.00 JPY + Equity:Opening-Balances:Cost -1000 USD + :END: + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 177 + :UUID: 45605775-F9E3-4C83-8BF2-616905178E82 + :END: + [2008-04-12 Sat] +* DONE [#A] Crash on input. + - State "DONE" [2008-07-17 Thu 17:38] + - State "TODO" [2008-04-06 Sun 10:23] \\ + Martin Blais <blais@furius.ca> writes: + > I think that the bug is related to the missing currency after the @ + > sign. + :DATA: +;; Assets:Investments:HSBC-Broker ------------------------------------------------------------ + +2007/12/31 * Start of year / Opening balances. + Assets:Investments:HSBC-Broker 100 IVV + Assets:Investments:HSBC-Broker -15360.60 USD ; cost basis of older purchase + Equity:Opening-Balances + +2008/01/03 * Dividends received for IVV holding. + Assets:Investments:HSBC-Broker 79.79 USD + Income:Interest:Dividends + + +2008/02/04 * Sell 100 IVV - on 2008/01/30 + Assets:Investments:HSBC-Broker -100 IVV @ 136.2901 + Assets:Investments:HSBC-Broker -13629.01 USD + Expenses:Financial:Commissions 24.99 USD + Expenses:Financial:Fees 0.15 USD + Expenses:Financial:Fees 2.00 USD + :END: + :OUTPUT: +banane:~/__accounting/.../rbcinv/invest$ ledger -f /tmp/b -V register hsbc:broker +Segmentation fault (core dumped) +banane:~/__accounting/.../rbcinv/invest$ + :END: + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 46 + :UUID: 703505C9-B702-4139-B64A-FD3CF592E720 + :END: + [2008-04-06 Sun] +* DONE [#A] Crash on input. + - State "DONE" [2008-07-17 Thu 17:38] + :DATA: +2008/01/02 ! Sell -- on 2007/12/27 -- CRA -- APPLERA CORP COM CELERA GROUP CA EXCHANGE RATE .96760 + Assets:Investments:RBC-Broker:Account-CAD -8.00 CRA @ 16.93 USD + Assets:Investments:RBC-Broker:Account-CAD 121.41 CAD + Expenses:Financial:Commissions -9.95 USD + Expenses:Financial:Fees -0.01 USD + :END: + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 47 + :UUID: B2B79746-5E3B-40D3-B6ED-CCF27364DD5F + :END: + [2008-04-06 Sun] +* DONE [#A] Dates (used with -b -e and -p parameters) are broken + - State "DONE" [2008-07-17 Thu 06:20] \\ + Patch checked in. Thanks, Nathan! + - State "TODO" [2008-04-06 Sun 21:59] \\ + Nathan Jones <nathanj@insightbb.com> writes: + > The attached patch plus the one in #38 should fix this. + The release (2.6.0.90) doesn't seem to properly parse dates. The svn + version (rev. 1048) works fine for full dates (yyyy/mm/dd) with the -b -e + params but nothing else works. For example in the following only the last + one works: + :SCRIPT: +ledger -f my.ledger -b mar -e apr print +ledger -f my.ledger -b 03/01 -e -04/01 apr print +ledger -f my.ledger -b 03/01 -e 04/01 print +ledger -f my.ledger -b 08/03/01 -e 08/04/01 print +ledger -f my.ledger -b 2008/03/01 -e 2008/04/01 print + :END: + The -p param doesn't seem to work at all. + :PROPERTIES: + :Submitter: kmt <kmt@ftml.net> + :Version: 2.6.0.90 + :Ticket: 49 + :Attachments: 290.patch + :UUID: A95B2E0F-095D-4314-BC4D-3CEC42203FB1 + :END: + [2008-04-06 Sun] +* DONE [#A] Entry command produces two liability transactions + - State "DONE" [2008-07-17 Thu 22:01] + - State "TODO" [2008-05-03 Sat 22:27] \\ + This is being a real problem for drewr, arete and pll! This one gets fixed + for 2.6.1. + :OUTPUT: +arete$ ledger entry 2007/11/11 safeway groceries \$10.00 american + +2007/11/11 Safeway + Expenses:Groceries $10.00 + Liabilities:American Express $-30.17 + Liabilities:American Express $20.17 + :END: + :PROPERTIES: + :Submitter: Will Glozer <will@glozer.net> + :Version: 2.6 + :Ticket: 8 + :UUID: D7DD54D7-8870-4D6D-92A0-90717692F8F2 + :END: + [2007-11-12 Mon] +* DONE [#A] ledger 2.6 shows no timelog entries + - State "DONE" [2008-07-17 Thu 19:08] + - State "TODO" [2008-08-18 Mon 02:15] \\ + Simon Michael <simon@joyful.com> writes: + > And if ends with a "i" record, ledger gives a bus error. This is on + > leopard. + Ledger 2.5 shows entries in my timelog file, but 2.6.1-pre shows none. There + is no parse error. + :PROPERTIES: + :Submitter: Simon Michael <simon@joyful.com> + :Version: 2.6.1b + :Ticket: 57 + :UUID: C13F0BDF-4E15-442E-BBB7-265B0A37457C + :END: + [2008-04-09 Wed] +* DONE [#A] Ledger fails to balance a simple entry + - State "DONE" [2008-07-28 Mon 02:05] \\ + This was quite the nasty little bug. + I just installed v2.6.1 and ledger reports errors with some transactions + that were fine with v2.5: + :OUTPUT: +[21:51:49 vinod]:~/src/ledger $ ledger --version +Ledger 2.6.1, the command-line accounting tool + +[21:51:55 vinod]:~/src/ledger $ ledger bal +While balancing entry: + 2007/02/02 RD VMMXX + Assets:Investments:Vanguard:VMMXX 0.350 VMMXX @ $1.00 + Income:Dividends:Vanguard:VMMXX $-0.35 +Unbalanced remainder is: + $-0.35 +Error: "/home/vinod/data/ledger.dat", line 52379: Entry does not balance + :END: + :PROPERTIES: + :Submitter: Vinod Kurup <vvkurup@gmail.com> + :Version: 2.6.1b + :Ticket: 205 + :UUID: 0CA014F9-E309-4840-9085-71EC1F46DEC1 + :END: + [2008-07-28 Mon] +* DONE [#A] Make -e use an inclusive end date, and -E an exclusive one + - State "DONE" [2008-07-17 Thu 06:22] \\ + -e has been reverted back to its old behavior, to avoid confusing people. + Right now (as of today) -e was made exclusive, but this isn't right; I need + another option for exclusivity. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 37 + :UUID: A440BB5E-072B-4C75-A235-C551EA090F81 + :END: + [2008-04-04 Fri] +* DONE [#A] Marking a transaction cleared may delete text in ledger-mode :EMACS: + - State "DONE" [2008-07-18 Fri 02:28] + I started the groundwork for this, now I just have to add code to insert + whitespace if needed to keep each transaction valid. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 70 + :UUID: 0EB5602F-66BE-46C0-8A74-5EB5DBAF2E07 + :END: + [2008-04-11 Fri] +* DONE [#A] Reconciling is broken again; I need a way to verify Emacs output :EMACS: + - State "DONE" [2008-07-17 Thu 23:40] \\ + Reconciling is now line-based in 2.6.1, not character based (which has serious + issues with UTF-8 at the moment). + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 64 + :UUID: 7A8C49FB-F9B8-4ECF-8720-9E29559F3CA6 + :END: + [2008-04-11 Fri] +* DONE [#A] Strip \r from lines when parsing on Windows + - State "DONE" [2008-07-17 Thu 18:31] + It sounds like I'm not stripping the \r from the \r\n sequence, and thus + it's interpreting the \r as part of the file name. I'll add this to the + buglist for 3.0. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 43 + :UUID: 458B2B74-AF2D-4D9D-89E4-D8AC26CFD531 + :END: + [2008-04-05 Sat] +* DONE [#A] trailing whitespace is significant in 2.6 + - State "DONE" [2008-04-05 Sat 18:56] \\ + The first patch fixes parsing account names when a single space follows. + This might close ticket #3. + - State "TODO" [2008-04-05 Sat 18:55] \\ + The following patch, submitted by Nathan Jones, proposes to fix this problem. + - State "TODO" [2007-09-22 Sat 04:26] \\ + Simon, have you tried this with 2.6.1-svn? I believe this is something I + fixed. + Unlike 2.5, 2.6 considers an account name followed by whitespace to be + different from one without (when no amount is specified). + :PROPERTIES: + :Submitter: Simon Michael <simon@joyful.com> + :Version: 2.6 + :Ticket: 3 + :Attachments: 288.patch + :UUID: FB2330E1-AD78-4559-A885-A488DFDF3DC1 + :END: + [2007-09-22 Sat] +* DONE [#B] -e doesn't seem to work for providing an end date + - State "DONE" [2008-04-04 Fri 14:34] \\ + There was a problem with the -e date parsing. I now interpret "-e june" + to mean that you want the report to end AT June, rather than IN June. + :DATA: +2008/03/20 Grocery Store + Travel:Home 2.3 miles + Wear & Tear:Car + +2008/03/31 Office + Travel:Work 16 miles + Wear & Tear:Car + +2008/04/01 Office + Travel:Work 16 miles + Wear & Tear:Car + +2008/04/02 Office + Travel:Work 16 miles + Wear & Tear:Car + +2008/04/03 Office + Travel:Work 16 miles + Wear & Tear:Car + +2008/04/04 Office + Travel:Work 16 miles + Wear & Tear:Car + :END: + :OUTPUT: +$ ledger -f /tmp/mileage.ledger -b 2008-03-31 reg travel +2008/03/31 Office Travel:Work 16.7 miles 16.7 miles +2008/04/01 Office Travel:Work 16.7 miles 33.4 miles +2008/04/02 Office Travel:Work 16.7 miles 50.1 miles +2008/04/03 Office Travel:Work 16.7 miles 66.8 miles +2008/04/04 Office Travel:Work 16.7 miles 83.5 miles +$ ledger -f /tmp/mileage.ledger -b 2008-03-31 -e 2008-04-05 reg travel +$ + :END: + Shouldn't that last command give me the same output as the former? + :PROPERTIES: + :Submitter: drewr <#ledger> + :Version: 2.6 + :Ticket: 36 + :UUID: 1DE6FB08-93D2-47C8-A5A3-3379BA76360D + :END: + [2008-04-04 Fri] +* DONE [#B] Command results in assertion failure + - State "DONE" [2008-07-17 Thu 17:44] + The command is: + :SCRIPT: +ledger -s bal --sort O wedding + :END: + This is against my own ledger file. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 23 + :UUID: AB684BBE-F093-4F77-BCFB-2F4E0D60AA9C + :END: + [2007-12-10 Mon] +* DONE [#B] Coredump. + - State "DONE" [2008-07-17 Thu 17:50] + :DATA: +2008/01/02 * Sell -- on 2007/12/27 -- CRA -- APPLERA CORP COM CELERA GROUP CA EXCHANGE RATE .96760 + Assets:Investments:RBC-Broker:Account-CAD -8.00 CRA @ 16.93 USD ; lot:ba8c951719fd + Expenses:Financial:Commissions 9.95 USD + Expenses:Financial:Fees 0.01 USD + Assets:Investments:RBC-Broker:Account-CAD 125.48 USD + Assets:Investments:RBC-Broker:Account-CAD -125.48 USD ; @ 0.96760 USD + Assets:Investments:RBC-Broker:Account-CAD 121.41 CAD + :END: + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 50 + :UUID: A18B37A4-68DB-4F3A-92D5-3962D010CA0B + :END: + [2008-04-06 Sun] +* DONE [#B] Crash on input -- spurious comma + - State "DONE" [2008-07-17 Thu 17:49] + :DATA: +2008/02/25 * bla bla bnla + Assets:Fixed:Home 235000.00 CAD + Expenses:Home:Acquisition:Escrow -82250.00 CAD + Liabilities:RBC:Mortgage:Loan -1.00 CAD, ; opening of account + Liabilities:RBC:Mortgage:Loan -152749.00 CAD + :END: + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 48 + :UUID: 517CB118-49A5-42B2-ACFD-1A63DCF163AA + :END: + [2008-04-06 Sun] +* DONE [#B] Crash on input. + - State "DONE" [2008-07-17 Thu 17:45] + :DATA: +2008/01/02 ! Sell -- on 2007/12/27 -- CRA -- APPLERA CORP COM CELERA GROUP CA EXCHANGE RATE .96760 + Assets:Investments:RBC-Broker:Account-CAD -8.00 CRA @ 16.93 USD + Assets:Investments:RBC-Broker:Account-CAD 21.41 CAD + Expenses:Financial:Commissions -9.95 USD + Expenses:Financial:Fees -0.01 USD + :END: + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 45 + :UUID: 93CFAFEB-46EA-4E47-8F0A-069309D6EE3A + :END: + [2008-04-06 Sun] +* DONE [#B] Crash reading .timelog file + - State "DONE" [2008-07-17 Thu 18:08] + 2.6b aborts if the last entry is the timelog is an "in" event. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 128 + :UUID: C7A32276-11A7-44F1-99CD-6F0CA7330340 + :END: + [2008-04-11 Fri] +* DONE [#B] Expressions don't work. + - State "DONE" [2008-07-17 Thu 21:37] + - State "TODO" [2008-04-12 Sat 14:58] \\ + Martin Blais <blais@furius.ca> writes: + > Note the typo in the error too: "evalute" -> "evaluate". + :DATA: +2007-12-31 * Start of year / Opening balances. + Assets:Investments:HSBC-Broker 1000 USD + Equity:Opening-Balances:Cost -101000 JPY @ 1/101.00 USD + :END: + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 178 + :UUID: DA9F2346-CD90-4E22-B2F0-2670532456BA + :END: + [2008-04-12 Sat] +* DONE [#B] Getting an abort with a self-referential pricing statement + - State "DONE" [2008-07-17 Thu 17:51] \\ + Getting this to work correctly is going to need more work (which has already + been logged as another bug). + :DATA: +2008/01/02 sell + Assets:Investments 130.41 CAD @ 1.03352277 CAD + Assets:Investments -8.00 CRA @ 16.93 USD + :END: + Passing this through the reg command produces a SIGABRT. + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 51 + :UUID: A21E4DCC-6112-441F-B76D-95CF47BA658D + :END: + [2008-04-06 Sun] +* DONE [#B] Install patches for Ledger 2.6 from Simon Michael + - State "DONE" [2008-07-17 Thu 21:41] \\ + I'm only taking the first patch for 2.6. The other two need a bit more + polish before I would put them in the standard distro, instead of just + posting them to the Wiki or some such. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 60 + :UUID: 0C311A59-701A-4D30-BBDB-924F12878724 + :Attachments: sm001.patch sm002.patch sm004.patch + :END: + [2008-04-11 Fri] +* DONE [#B] ledger SVN doesn't compile on freebsd-8 + - State "DONE" [2008-03-17 Mon 16:22] \\ + Clemens writes: + > Just for the record, there's a fix: + :PATCH: +diff --git a/ledger-2.6.0.90/datetime.h b/ledger-2.6.0.90/datetime.h +--- a/ledger-2.6.0.90/datetime.h ++++ b/ledger-2.6.0.90/datetime.h +@@ -96,7 +96,7 @@ class date_t + operator bool() const { + return when != 0; + } +- operator std::time_t() const { ++ operator std::time_t() /*const*/ { + return when; + } + operator std::string() const { + :END: + > Let's you compile and install. + - State "DONE" [2008-03-14 Fri 21:32] \\ + This is a known bug that was fixed in 2.6. If you need a back-patch for + 2.4.1, please let me know. + We have ledger-2.4 in the ports, but it segfaults on freebsd-8 (the current + dev version of the OS). The backtrace is incoherent, because the libs are + stripped and we have no symbols. Anyway, a sane person would want a more + recent ledger. The tarball exhibits the exact same problem as the one from + SVN: + :OUTPUT: +'uname -rims' -> FreeBSD 8.0-CURRENT i386 GENERIC +'gcc --version' -> gcc (GCC) 4.2.1 20070719 [FreeBSD] + +/src/bulk/ledger/trunk +0 $ gmake +gmake all-am +gmake[1]: Entering directory `/home/src/bulk/ledger/trunk' +/usr/local/bin/bash ./libtool --tag=CXX --mode=compile g++ -DHAVE_CONFIG_H -I. -I/l/include -g -O2 -c -o libamounts_la-amount.lo `test -f 'amount.cc' || echo './'`amount.cc + g++ -DHAVE_CONFIG_H -I. -I/l/include -g -O2 -c amount.cc -fPIC -DPIC -o .libs/libamounts_la-amount.o +In file included from amount.h:13, + from amount.cc:1: +datetime.h: In function 'long int operator-(const date_t&, const date_t&)': +datetime.h:141: error: conversion from 'date_t' to 'long int' is ambiguous +datetime.h:99: note: candidates are: date_t::operator time_t() const +datetime.h:96: note: date_t::operator bool() const +gmake[1]: *** [libamounts_la-amount.lo] Error 1 +gmake[1]: Leaving directory `/home/src/bulk/ledger/trunk' +gmake: *** [all] Error 2 + :END: + + I know C and i can do some gdb(1), but i don't have the C++ knowledge to + even fix this one. It looks not all that complicated. Maybe a little patch + could help the C++ compiler to figure out the type inference. + + I used emacs for quite some time, but got annoyed with its ancient lisp. So + using the common lisp version is currently not an option for me, and without + emacs one has to type way to much for some little reports. Could you please + bring the C++ version into a usable state again? perhaps it's not that much + work? + :PROPERTIES: + :Submitter: Clemens <finetouch> + :Version: 2.4.1 + :Ticket: 34 + :UUID: C1BE11BD-958D-4E67-8B85-5DA14CD375B4 + :END: + [2008-03-14 Fri] +* DONE [#B] ledger.el requires an absolute pathname for the ledger-binary-path :EMACS: + - State "DONE" [2008-07-17 Thu 22:09] + This caused me pain after a ledger upgrade. "ledger" should be sufficient if + it's in the path. + :PROPERTIES: + :Submitter: Simon Michael <simon@joyful.com> + :Version: 2.6 + :Ticket: 199 + :UUID: 7D40038A-DEED-47FA-8D02-0951E94CA175 + :END: + [2008-07-12 Sat] +* DONE [#B] Segmentation fault on import from GnuCash + - State "DONE" [2008-07-17 Thu 20:04] + - State "TODO" [2008-06-16 Mon 16:05] \\ + Luben Manolov <lubo@manolov.org> writes: + > Import of this GnuCash file causes Segmentation fault + I am trying to import a simple GnuCash file and I am getting "Segmentation + fault" error. Please find attached the sample file. + :OUTPUT: +./ledger -f sample.gnucash balance +While balancing entry: + 2008/06/16 + Segmentation fault + :END: + :PROPERTIES: + :Submitter: Luben Manolov <lubo@manolov.org> + :Version: 2.6 + :Ticket: 198 + :UUID: 266D96D2-DEB5-4BD9-A51B-B2F652E2F550 + :Attachments: sample.gnucash + :END: + [2008-06-16 Mon] +* DONE [#B] Some at-signs are not properly escaped in documentation :DOC: + - State "DONE" [2008-03-27 Thu 19:42] + Some of the at signs are not properly escaped in the texi + documentation. This leads to great confusion when trying to figure out how + to use commodity transactions. + :PROPERTIES: + :Submitter: thedward <thedward@barsoom.net> + :Version: 2.6 + :Ticket: 31 + :Attachments: ledger-texi.patch + :UUID: A7CA0F5B-1F08-417A-9071-A223601100CA + :END: + [2008-01-28 Mon] +* DONE [#C] Entry command doesn't match debit account when description is unmatched + - State "DONE" [2008-07-20 Sun 20:32] + I think I've isolated a bug with the entry command where I get "Equity" + instead of a valid debit account: + :OUTPUT: +$ ledger entry 2008/07/18 "Pei Wei" food 20 checking + +2008/07/18 Pei Wei + Expenses:Food:Out $ 20.00 + Assets:Checking + +$ ledger entry 2008/07/18 "Foo Bar" food 20 checking + +2008/07/18 Foo Bar + Expenses:Food $ 20.00 + Equity + :END: + + The first command proves that ledger understands I have an `Assets:Checking` + account. That's because I already have entries for `Pei Wei`. + + If I enter a description that doesn't match a previous entry, it doesn't + match `checking` to `Assets:Checking`. + :PROPERTIES: + :Submitter: drewr <#ledger> + :Version: 5fbec3582319ca6423a43c9125842be5f969e8ee + :Ticket: 203 + :UUID: FF8CE4C5-03B3-4FCA-85BD-52A9DB191B4B + :END: + [2008-07-18 Fri] +* DONE [#C] Multiple commodities in gnucash crash ledger + - State "DONE" [2008-07-17 Thu 21:26] + - State "TODO" [2008-03-27 Thu 19:54] \\ + I still have to review the patch and make the changes, before this gets + closed. + - State "TODO" [2008-03-27 Thu 15:20] \\ + slanack writes: + > The proposed Fix works for me. The problem was that <split:quantity> + > received the `transaction commodity' instead of the correct `account + > commodity'. There should really be a check if the account commodity has + > been defined. + I am using transactions between accounts with different base commodities in + gnucash. Ledger reports a segfault when reading the gnucash file and using + the command `print`. + :PROPERTIES: + :Submitter: slanack + :Version: 2.6.0.90 + :Ticket: 35 + :UUID: DAAF3481-1B7A-4F4A-9EC6-575104655B1B + :Attachments: gnucash.cc.patch gnucash-minimal.xml + :END: + [2008-03-23 Sun] +* DONE [#C] My "bal" command is broken again + - State "DONE" [2008-07-17 Thu 21:22] + :OUTPUT: +~/Reference/Computing/Systems/Linux $ bal + 3,848.34 + EC 450.05 Assets +Error: Cannot compare amounts with different commodities: EC and $ + :END: + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 66 + :UUID: 8159EF00-B95D-4E83-9927-7DB461CD2CC9 + :END: + [2008-04-11 Fri] +* DONE [#C] Remove bogus reference to Emacs in project documentation :DOC: + - State "DONE" [2008-07-16 Wed 03:59] + The gnucash docs talk about there someday being an Emacs mode. There is + already one. + :PROPERTIES: + :Submitter: bpt <#ledger> + :Version: 2.4.1 + :Ticket: 10 + :UUID: B81ADF25-F176-4ABC-9C2B-1090E4F2FA7D + :END: + [2007-12-10 Mon] +* DONE [#C] Segfault with commodity price in budget. + - State "DONE" [2008-07-17 Thu 20:09] + :DATA: +~ Monthly + Assets:Invest 2 AAPL @ $30.00 + Assets:Bank -2 AAPL + :END: + It works if the '@ $30.00' is removed. The problem is that entry is null + when called through parse_transactions. Backtrace: + :OUTPUT: +#0 0x080632ab in datetime_t (this=0xbfb4af88, _when=@0x40) at datetime.h:173 +#1 0x080973ac in ledger::entry_t::actual_date (this=0x0) at journal.h:180 +#2 0x080b7fc7 in ledger::parse_transaction ( + line=0x8119e20 " Assets:Invest 2 AAPL @ $30.00", account=0x813be00, + entry=0x0) at textual.cc:258 +#3 0x080b9480 in ledger::parse_transactions (in=@0xbfb4b4bc, + account=0x813be00, entry=@0x813e2f8, kind=@0xbfb4b2f8, beg_pos=63) + at textual.cc:340 +... + :END: + :PROPERTIES: + :Submitter: Nathan Jones <nathanj@insightbb.com> + :Version: 2.6.0.90 + :Ticket: 191 + :UUID: A4F87484-1B1D-4C76-B0AB-70E20FBA9D1B + :END: + [2008-04-23 Wed] +* DONE [#C] When reporting the unbalanced remainder, round it :FEATURE: + - State "DONE" [2008-07-17 Thu 20:52] + This is so that it shows what ledger is really thinking. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 125 + :UUID: 4BF95CDC-972F-4F39-9F54-7BEFD404F9AA + :END: + [2008-04-11 Fri] +* WONTFIX [#B] No commodity when amount contains simple math operation + - State "WONTFIX" [2007-11-09 Fri 23:34] \\ + This expected behavior. If you multiply or divide two commoditized + amounts together, the second commodity is dropped in favor of the first. + You'll have to use "30 AAPL * .01". + Use the following legder data file (sample2.dat) + :DATA: +2004/05/01 * Investment balance + Assets:Brokerage 100 / 30 AAPL @ $30.00 + Equity:Opening Balances + :END: + + Create the bal report: + :OUTPUT: +$ ledger -f sample2.dat bal + 3.333333 Assets + $-99.99999 Equity +-------------------- + 3.333333 + $-99.99999 + :END: + + Notice that the "AAPL" commodity is gone. + :PROPERTIES: + :Submitter: Levin <zslevin@gmail.com> + :Version: 2.6 + :Ticket: 7 + :UUID: 4290A2E5-8CFB-4529-87DE-F088719AF13A + :END: + [2007-11-09 Fri] +* WONTFIX [#B] Problem with pricing specification in prices.db file + - State "WONTFIX" [2008-07-17 Thu 21:42] \\ + Pricing info is not used for balancing entries. For that, you'd need to use + "@ ... USD" for the halfg and gouda amounts, so that Ledger could be certain + your entries balances to zero. + - State "TODO" [2008-04-05 Sat 20:09] \\ + I changed it to this below, and ledger stopped complaining: + :DATA: +2007/03/07 Irena + Liabilities:Cash:Irena 7.00 USD + Liabilities:Order1:Irena -1 gouda + +2007/03/07 Irena + Liabilities:Cash:Irena 11.00 USD + Liabilities:Order1:Irena -4 halfg + :END: + :OUTPUT: +djw@hector:~$ ledger bal + +2007/03/07 Irena + Liabilities:Cash:Irena 18.00 USD + Liabilities:Order1:Irena -4 halfg + Liabilities:Order1:Irena -1 gouda +Error: /home/djw/milk.ledger, line 106: Entry above does not balance; remainder is: 18.00 USD +-1 gouda +-4 halfg + :END: + Here is what is in the prices.db file: + :DATA: +C 1.00 USD = $1.21 +P 2007/03/04 00:00:00 halfg 2.75 USD +P 2007/03/04 00:00:00 gouda 7 USD + :END: + So you multiply 4*2.75 and add 7, you get 18. Since the units are USD, what + is the beef? Why isn't ledger seeing 1 gouda and 4 halfg as 18 USD? + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 42 + :UUID: 43CFF7FF-DA09-478C-AED1-2D2756BACA09 + :END: + [2008-04-05 Sat] +* WONTFIX [#C] Balance calculations using the '=' operator are off + - State "WONTFIX" [2008-08-15 Fri 04:14] \\ + This feature is not ready for 2.6.1, and is being pushed to 3.0 where this + issue has been fixed. + When I run 'ledger --tail 20 reg assets:cash' with my current ledger data, + the final balance is way, way off. Something is being miscalculated. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6.1b + :Ticket: 209 + :UUID: F32E914F-D485-427B-89E9-33C762CC1A47 + :END: + [2008-08-02 Sat] +* WONTFIX [#C] Non-balanced virtual transaction should fail. + - State "WONTFIX" [2008-07-17 Thu 20:44] \\ + This is not an error because: + + 1. specifying no amount is the same as specifying an uncommoditized zero. + 2. the second line will "auto-balance" with the first line. + 3. the third line simply is a no-op, which I allow for the sake of script + writers. + + There could be a warning for something like this, but then that's the + danger of using () around an account name: you are explicitly stating you + do not wish the transaction to be balanced. + - State "TODO" [2008-04-23 Wed 13:35] \\ + Martin Blais <blais@furius.ca> writes: + > Well... should "probably" fail. I mean, it does nothing, so it's + > probably an error. I'd make it fail. + Shouldn't this fail? + :DATA: +2004/03/25 Donations + Assets:Checking $100.00 + Assets:Savings + (Income:Donations) + :END: + :PROPERTIES: + :Submitter: Martin Blais <blais@furius.ca> + :Version: 2.6 + :Ticket: 190 + :UUID: 75E83651-B130-4978-89C7-DFED4E874E8F + :END: + [2008-04-23 Wed] +* WORKSFORME [#A] Monthly register command displays nothing + - State "WORKSFORME" [2008-07-17 Thu 20:12] \\ + This has apparently been fixed by the recent date/time bug fixes. + The command is: + :SCRIPT: +ledger -p 2005 -e 2005/08/17 --monthly reg + :END: + This is against my own ledger file. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 30 + :UUID: 841041A2-925D-4797-BE44-11BFC7333054 + :END: + [2007-12-10 Mon] +* WORKSFORME [#A] Weekly register report is completely broken in 2.6 + - State "WORKSFORME" [2008-07-17 Thu 20:11] \\ + This has apparently been fixed by all the other date/time fixes done today. + The command is: + :SCRIPT: +ledger --weekly reg food + :END: + This works fine in 2.5. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 26 + :UUID: 30383931-3060-4999-8FD3-9002E02366A0 + :END: + [2007-12-10 Mon] +* WORKSFORME [#B] ledger -MA doesn't give a monthly report if some months have no transactions + - State "WORKSFORME" [2008-07-17 Thu 20:14] \\ + This works for me. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 61 + :UUID: FD118D79-3B8F-48CE-89D0-F0FFD46F6C49 + :END: + [2008-04-11 Fri] +* WORKSFORME [#B] Problems with the prices.db file + - State "WORKSFORME" [2008-07-17 Thu 21:45] \\ + Pricing entries must start with a capital P, not a lowercase p. + + This bug also mentions other issues, which are now contained in another + bug. + - State "TODO" [2008-04-05 Sat 20:06] \\ + However, even though I do not receive parse errors any longer, the + price-db command does not work the way I expect it to. When I issue a + 'bal' option, ledger still outputs the values in their commodity rather + than the dollar amount, so even though I am not receiving an error, it + still does not seem to work for me. + My prices.db file looks like: + :DATA: +p 2007/01/14 02:18:01 WMCVX $5.04 +p 2007/01/14 02:18:02 WMICX $6.65 + :END: + Notice there is no carriage return after the second line and that the file + begins on line 1. + + When I run 'ledger --price-db prices.db bal' I get the following: + :OUTPUT: +Error: prices.db, line 2: Failed to parse dateP +Error: Errors parsing file 'life/finances/ledger/prices.db' + :END: + + If I have a carriage return on the second line, I get errors for both line 2 + and line 3. If i have one entry on a single line, I get an error for line 2. + + Any ideas? + + Also, I would like to get the prices.db perl script working to automatically + grab the values from Fidelity, but I have not been able to do anything + beyond installing the appropriate perl modules. If there are any + instructions for this usage, I would appreciate it. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 40 + :UUID: B8173D32-D7EB-4619-8488-B2C641431FDE + :END: + [2008-04-05 Sat] +* WORKSFORME [#C] ledger -Mn + - State "WORKSFORME" [2008-08-17 Sun 20:13] + Is not the same as: ledger -M -n + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 126 + :UUID: 2C3B5DCE-AB7F-41A2-BF93-56CC1222AE64 + :END: + [2008-04-11 Fri] +* INVALID [#B] Remove bogus reference to Emacs in project documentation (2.6) + - State "INVALID" [2008-07-13 Sun 22:16] + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 72 + :UUID: 7455E4A7-16FD-4F41-8A33-CF44F6E690B2 + :END: + [2008-04-11 Fri] +* DUPLICATE [#A] Bug with date ranges + - State "DUPLICATE" [2008-04-04 Fri 14:35] \\ + This has been fixed, see the comments in #36. + I'm using the latest source from CVS and it appears the `-e` option is + broken. For example this works as expected: + :OUTPUT: +% ledger -b 2006/05/01 bal + :END: + +But this does not. No output whatsoever: + :OUTPUT: +% ledger -b 2006/05/01 -e 2006/05/31 bal + :END: + +This also doesn't work. It just shows `Opening Balances: 0`: + :OUTPUT: +% ledger -p "last month" bal + :END: + :PROPERTIES: + :Submitter: Eric Davis <edavis@insanum.com> + :Version: 2.6 + :Ticket: 17 + :UUID: FE3E08C0-802A-4FAA-B8BA-93D81C061148 + :END: + [2007-12-10 Mon] +* DUPLICATE [#A] DOS format line endings are fooling the parser + - State "DUPLICATE" [2008-08-16 Sat 03:56] \\ + Duplicated by #43. + The \r\n ending is having only the \n stripped, making the \r appear as part + of the filename when doing a !include. + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 129 + :UUID: 6DF2250F-C54D-4F67-AFB6-F8656020D394 + :END: + [2008-04-11 Fri] +* DUPLICATE [#B] Need to strip \r from \r\n line endings + - State "DUPLICATE" [2008-07-13 Sun 22:38] + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 139 + :UUID: C7A61E89-08D1-4151-AF2E-92F666148F19 + :END: + [2008-04-11 Fri] +* DUPLICATE [#B] Problems parsing an entry + - State "DUPLICATE" [2008-07-18 Fri 02:12] + :OUTPUT: +djw@hector:~$ ledger bal + +2007/03/07 Irena +Liabilities:Cash:Irena 18.00 USD +Liabilities:Order1:Irena -4 halfg +Liabilities:Order1:Irena -1 gouda +Error: /home/djw/milk.ledger, line 106: Entry above does not balance; remainder is: 18.00 USD +-1 gouda +-4 halfg + :END: + Here is what is in the prices.db file: + :DATA: +C 1.00 USD = $1.21 +P 2007/03/04 00:00:00 halfg 2.75 USD +P 2007/03/04 00:00:00 gouda 7 USD + :END: + So you multiply 4*2.75 and add 7, you get 18. Since the units are USD, what + is the beef? Why isn't ledger seeing 1 gouda and 4 halfg as 18 USD? + :PROPERTIES: + :Submitter: John Wiegley <johnw@newartisans.com> + :Version: 2.6 + :Ticket: 133 + :UUID: AD876FB0-E7B8-4C89-9E23-2D25AF8D5F0A + :END: + [2008-04-11 Fri] +* DUPLICATE [#B] Reconciling doesn't work in ledger.el :EMACS: + - State "DUPLICATE" [2008-07-16 Wed 03:56] \\ + Duplicated by #64. + I've tried version 2.5 but have had some problems. + + I use Carbon Emacs on Mac OS X to edit my Ledger files. Unfortunately the + reconcile functionality doesn't work any more. Pressing the space bar + doesn't always toggle an entry, sometimes it needs to be pressed twice, + sometimes it never goes. Additionally, even if some entries are toggled, + nothing is changed in the main file and pressing C-c C-c just re-sets the + reconcile window back to it's original state. + + I've tried with and without the new ledger-clear-whole-entries variable set. + :PROPERTIES: + :Submitter: Karen Cooke <karen.cooke@gmail.com> + :Version: 2.6 + :Ticket: 14 + :UUID: 2B02E2FD-DCF8-4CD8-A7FA-F83F5DAE3F55 + :END: + [2007-12-10 Mon] +* DUPLICATE [#C] Entry command produces duplicate source transactions + - State "DUPLICATE" [2008-01-31 Thu 14:57] \\ + drewr writes: + > This is a duplicate of ticket #8. + - State "TODO" [2008-01-30 Wed 17:36] \\ + drewr writes: + > This happens with 2.6.1 as well. + If I have a ledger file like so: + :DATA: +2008/01/24 Foo + Expenses:Foo $ 136.56 + Assets:Checking + :END: + and then run `ledger entry 2008/01/26 foo expen 45 check`, I get: + :OUTPUT: +2008/01/26 Foo + Expenses:Foo $ 45.00 + Assets:Checking $ -136.56 + Assets:Checking $ 91.56 + :END: + :Submitter: drewr <#ledger> + :Version: 2.6 + :Ticket: 32 + :UUID: EA246228-3EC7-4834-B55A-455DBA58116C + :END: + [2008-01-30 Wed] @@ -26,6 +26,7 @@ else fi INCDIRS="-I/opt/local/include -I/usr/local/include -I/usr/include/httpd/xml" +INCDIRS="$INCDIRS -I/opt/local/include/libofx" INCDIRS="$INCDIRS -I/usr/include/python2.5" LIBDIRS="-L/opt/local/lib -L/usr/local/lib" @@ -4,6 +4,7 @@ #include <list> #include <sstream> #include <cstdlib> +#include <memory> #include <gmp.h> diff --git a/configure.in b/configure.in index 866334f0..f82cbfd4 100644 --- a/configure.in +++ b/configure.in @@ -2,10 +2,10 @@ # Process this file with autoconf to produce a configure script. AC_PREREQ(2.59) -AC_INIT(ledger, 2.6.1, johnw@newartisans.com) -AM_INIT_AUTOMAKE(ledger, 2.6.1) +AC_INIT([ledger],[2.6.1],[johnw@newartisans.com]) AC_CONFIG_SRCDIR([main.cc]) AC_CONFIG_HEADER([acconf.h]) +AM_INIT_AUTOMAKE([dist-bzip2 foreign]) # Checks for programs. AC_PROG_CXX diff --git a/data b/data new file mode 160000 +Subproject e4eb5c28c80b799762139c700ada3f5681b72cc @@ -447,6 +447,8 @@ int main(int argc, char * argv[], char * envp[]) std::auto_ptr<journal_t> journal; try { + std::ios::sync_with_stdio(false); + #if DEBUG_LEVEL < BETA ledger::do_cleanup = false; #endif @@ -4,7 +4,8 @@ from distutils.core import setup, Extension import os -libs = ["amounts", "boost_python", "gmp"] +defines = [('PYTHON_MODULE', 1)] +libs = ["amounts", "boost_python", "gmp"] setup(name = "Amounts", version = "2.6.1", @@ -13,6 +14,6 @@ setup(name = "Amounts", author_email = "johnw@newartisans.com", url = "http://www.newartisans.com/johnw/", ext_modules = [ - Extension("amounts", ["amounts.cc"], + Extension("amounts", [os.path.join(os.environ['SRCDIR'], "amounts.cc")], define_macros = [('PYTHON_MODULE', 1)], libraries = libs)]) @@ -201,15 +201,13 @@ transaction_t * parse_transaction(char * line, account_t * account, goto finished; if (p == ';') goto parse_note; - if (p == '=' && entry) - goto parse_assign; try { unsigned long beg = (long)in.tellg(); xact->amount_expr = parse_amount_expr(in, xact->amount, xact.get(), - PARSE_VALEXPR_NO_REDUCE | PARSE_VALEXPR_NO_ASSIGN); + PARSE_VALEXPR_NO_REDUCE); unsigned long end = (long)in.tellg(); xact->amount_expr.expr = std::string(line, beg, end - beg); @@ -243,8 +241,7 @@ transaction_t * parse_transaction(char * line, account_t * account, unsigned long beg = (long)in.tellg(); if (parse_amount_expr(in, *xact->cost, xact.get(), - PARSE_VALEXPR_NO_MIGRATE | - PARSE_VALEXPR_NO_ASSIGN)) + PARSE_VALEXPR_NO_MIGRATE)) throw new parse_error ("A transaction's cost must evaluate to a constant value"); @@ -291,80 +288,6 @@ transaction_t * parse_transaction(char * line, account_t * account, DEBUG_PRINT("ledger.textual.parse", "line " << linenum << ": " << "Reduced amount is " << xact->amount); -parse_assign: - if (entry != NULL) { - // Add this amount to the related account now - - account_xdata_t& xdata(account_xdata(*xact->account)); - - if (xact->amount) { - xdata.value += xact->amount; - DEBUG_PRINT("ledger.textual.parse", "line " << linenum << ": " << - "XACT assign: account total = " << xdata.value); - } - - // Parse the optional assigned (= AMOUNT) - - if (in.good() && ! in.eof()) { - p = peek_next_nonws(in); - if (p == '=') { - in.get(p); - DEBUG_PRINT("ledger.textual.parse", "line " << linenum << ": " << - "Found a balance assignment indicator"); - if (in.good() && ! in.eof()) { - amount_t amt; - - try { - unsigned long beg = (long)in.tellg(); - - if (parse_amount_expr(in, amt, xact.get(), - PARSE_VALEXPR_NO_MIGRATE)) - throw new parse_error - ("An assigned balance must evaluate to a constant value"); - - DEBUG_PRINT("ledger.textual.parse", "line " << linenum << ": " << - "XACT assign: parsed amt = " << amt); - - unsigned long end = (long)in.tellg(); - - amount_t diff; - if (xdata.value.type == value_t::AMOUNT) - diff = amt - *((amount_t *) xdata.value.data); - else if (xdata.value.type == value_t::BALANCE) - diff = amt - ((balance_t *) xdata.value.data)->amount(amt.commodity()); - else if (xdata.value.type == value_t::BALANCE_PAIR) - diff = amt - ((balance_pair_t *) xdata.value.data)->quantity.amount(amt.commodity()); - else - diff = amt; - - DEBUG_PRINT("ledger.textual.parse", "line " << linenum << ": " << - "XACT assign: diff = " << diff); - - if (! diff.realzero()) { - if (xact->amount) { - transaction_t * temp - = new transaction_t(xact->account, diff, TRANSACTION_CALCULATED); - entry->add_transaction(temp); - - DEBUG_PRINT("ledger.textual.parse", "line " << linenum << ": " << - "Created balancing transaction"); - } else { - xact->amount = diff; - DEBUG_PRINT("ledger.textual.parse", "line " << linenum << ": " << - "Overwrite null transaction"); - } - xdata.value = amt; - } - } - catch (error * err) { - err_desc = "While parsing assigned balance:"; - throw err; - } - } - } - } - } - // Parse the optional note parse_note: @@ -833,8 +833,7 @@ value_expr_t * parse_value_term(std::istream& in, scope_t * scope, bool definition = false; if (c == '=') { in.get(c); - if ((flags & PARSE_VALEXPR_NO_ASSIGN) || - peek_next_nonws(in) == '=') { + if (peek_next_nonws(in) == '=') { in.unget(); c = '\0'; } else { @@ -1161,16 +1160,10 @@ value_expr_t * parse_logic_expr(std::istream& in, scope_t * scope, case '!': case '=': { bool negate = c == '!'; - if (! negate && (flags & PARSE_VALEXPR_NO_ASSIGN)) { - in.unget(); - break; - } - else if ((c = peek_next_nonws(in)) == '=') { + if ((c = peek_next_nonws(in)) == '=') in.get(c); - } - else { + else unexpected(c, '='); - } value_expr prev(node.release()); node.reset(new value_expr_t(negate ? value_expr_t::O_NEQ : value_expr_t::O_EQ)); @@ -280,7 +280,6 @@ bool compute_amount(value_expr_t * expr, amount_t& amt, #define PARSE_VALEXPR_RELAXED 0x02 #define PARSE_VALEXPR_NO_MIGRATE 0x04 #define PARSE_VALEXPR_NO_REDUCE 0x08 -#define PARSE_VALEXPR_NO_ASSIGN 0x10 value_expr_t * parse_value_expr(std::istream& in, scope_t * scope = NULL, |