diff options
Diffstat (limited to 'contrib')
-rw-r--r-- | contrib/ParseCcStmt.cs | 92 | ||||
-rwxr-xr-x | contrib/entry | 6 | ||||
-rwxr-xr-x | contrib/ledger-du | 14 | ||||
-rw-r--r-- | contrib/ledger.vim | 8 |
4 files changed, 60 insertions, 60 deletions
diff --git a/contrib/ParseCcStmt.cs b/contrib/ParseCcStmt.cs index f6b2f20b..c9ad1d55 100644 --- a/contrib/ParseCcStmt.cs +++ b/contrib/ParseCcStmt.cs @@ -41,7 +41,7 @@ using CSVReader; /** * @file ParseCcStmt.cs * - * @brief Provides a .NET way to turn a CSV report into Ledger entries. + * @brief Provides a .NET way to turn a CSV report into Ledger transactions. * * I use this code for converting the statements from my own credit card * issuer. I realize it's strange for this to be in C#, but I wrote it @@ -52,7 +52,7 @@ using CSVReader; namespace JohnWiegley { - public class Transaction + public class Posting { public DateTime Date; public DateTime PostedDate; @@ -63,90 +63,90 @@ namespace JohnWiegley public interface IStatementConverter { - List<Transaction> ConvertRecords(Stream s); + List<Posting> ConvertRecords(Stream s); } public class ConvertGoldMasterCardStatement : IStatementConverter { - public List<Transaction> ConvertRecords(Stream s) + public List<Posting> ConvertRecords(Stream s) { - List<Transaction> xacts = new List<Transaction>(); + List<Posting> posts = new List<Posting>(); using (CSVReader.CSVReader csv = new CSVReader.CSVReader(s)) { string[] fields; while ((fields = csv.GetCSVLine()) != null) { - if (fields[0] == "TRANSACTION DATE") + if (fields[0] == "POSTING DATE") continue; - Transaction xact = new Transaction(); + Posting post = new Posting(); - xact.Date = DateTime.ParseExact(fields[0], "mm/dd/yy", null); - xact.PostedDate = DateTime.ParseExact(fields[1], "mm/dd/yy", null); - xact.Payee = fields[2].Trim(); - xact.Code = fields[3].Trim(); - xact.Amount = Convert.ToDecimal(fields[4].Trim()); + post.Date = DateTime.ParseEpost(fields[0], "mm/dd/yy", null); + post.PostedDate = DateTime.ParseEpost(fields[1], "mm/dd/yy", null); + post.Payee = fields[2].Trim(); + post.Code = fields[3].Trim(); + post.Amount = Convert.ToDecimal(fields[4].Trim()); - if (xact.Code.Length == 0) - xact.Code = null; + if (post.Code.Length == 0) + post.Code = null; - xacts.Add(xact); + posts.Add(post); } } - return xacts; + return posts; } } public class ConvertMastercardStatement : IStatementConverter { - public List<Transaction> ConvertRecords(Stream s) + public List<Posting> ConvertRecords(Stream s) { - List<Transaction> xacts = new List<Transaction>(); + List<Posting> posts = new List<Posting>(); using (CSVReader.CSVReader csv = new CSVReader.CSVReader(s)) { string[] fields; while ((fields = csv.GetCSVLine()) != null) { - Transaction xact = new Transaction(); + Posting post = new Posting(); - xact.Date = DateTime.ParseExact(fields[0], "m/dd/yyyy", null); - xact.Payee = fields[2].Trim(); - xact.Code = fields[3].Trim(); - xact.Amount = - Convert.ToDecimal(fields[4].Trim()); + post.Date = DateTime.ParseEpost(fields[0], "m/dd/yyyy", null); + post.Payee = fields[2].Trim(); + post.Code = fields[3].Trim(); + post.Amount = - Convert.ToDecimal(fields[4].Trim()); - if (xact.Code.Length == 0) - xact.Code = null; + if (post.Code.Length == 0) + post.Code = null; - xacts.Add(xact); + posts.Add(post); } } - return xacts; + return posts; } } - public class PrintTransactions + public class PrintPostings { - public string DefaultAccount(Transaction xact) { - if (Regex.IsMatch(xact.Payee, "IGA")) + public string DefaultAccount(Posting post) { + if (Regex.IsMatch(post.Payee, "IGA")) return "Expenses:Food"; return "Expenses:Food"; } public void Print(string AccountName, string PayAccountName, - List<Transaction> xacts) + List<Posting> posts) { - foreach (Transaction xact in xacts) { - if (xact.Amount < 0) { - Console.WriteLine("{0} * {1}{2}", xact.Date.ToString("yyyy/mm/dd"), - xact.Code != null ? "(" + xact.Code + ") " : "", - xact.Payee); + foreach (Posting post in posts) { + if (post.Amount < 0) { + Console.WriteLine("{0} * {1}{2}", post.Date.ToString("yyyy/mm/dd"), + post.Code != null ? "(" + post.Code + ") " : "", + post.Payee); Console.WriteLine(" {0,-36}{1,12}", AccountName, - "$" + (- xact.Amount).ToString()); + "$" + (- post.Amount).ToString()); Console.WriteLine(" {0}", PayAccountName); } else { - Console.WriteLine("{0} {1}{2}", xact.Date.ToString("yyyy/mm/dd"), - xact.Code != null ? "(" + xact.Code + ") " : "", - xact.Payee); - Console.WriteLine(" {0,-36}{1,12}", DefaultAccount(xact), - "$" + xact.Amount.ToString()); + Console.WriteLine("{0} {1}{2}", post.Date.ToString("yyyy/mm/dd"), + post.Code != null ? "(" + post.Code + ") " : "", + post.Payee); + Console.WriteLine(" {0,-36}{1,12}", DefaultAccount(post), + "$" + post.Amount.ToString()); Console.WriteLine(" * {0}", AccountName); } Console.WriteLine(); @@ -166,17 +166,17 @@ namespace JohnWiegley IStatementConverter converter; - if (firstLine.StartsWith("TRANSACTION DATE")) { + if (firstLine.StartsWith("POSTING DATE")) { converter = new ConvertGoldMasterCardStatement(); } else { converter = new ConvertMastercardStatement(); } reader = new StreamReader(args[0]); - List<Transaction> xacts = converter.ConvertRecords(reader.BaseStream); + List<Posting> posts = converter.ConvertRecords(reader.BaseStream); - PrintTransactions printer = new PrintTransactions(); - printer.Print(CardAccount, BankAccount, xacts); + PrintPostings printer = new PrintPostings(); + printer.Print(CardAccount, BankAccount, posts); return 0; } diff --git a/contrib/entry b/contrib/entry index cc030d8e..ef1869da 100755 --- a/contrib/entry +++ b/contrib/entry @@ -6,11 +6,11 @@ fi line=`wc -l $LEDGER | awk '{print $1}'` -if ledger entry "$@" > /tmp/entry; then - cat /tmp/entry >> $LEDGER +if ledger xact "$@" > /tmp/xact; then + cat /tmp/xact >> $LEDGER else echo "$@" >> $LEDGER fi -rm /tmp/entry +rm /tmp/xact vi +$line $LEDGER diff --git a/contrib/ledger-du b/contrib/ledger-du index f5d7dd7d..580e916e 100755 --- a/contrib/ledger-du +++ b/contrib/ledger-du @@ -23,14 +23,14 @@ def report_file(path): print def find_files(path): - entries = os.listdir(path) - for entry in entries: - entry = join(path, entry) - if not islink(entry): - if isdir(entry) and entry != "/proc": - find_files(entry) + xacts = os.listdir(path) + for xact in xacts: + xact = join(path, xact) + if not islink(xact): + if isdir(xact) and xact != "/proc": + find_files(xact) else: - report_file(entry) + report_file(xact) args = sys.argv[1:] if len(args): diff --git a/contrib/ledger.vim b/contrib/ledger.vim index 2efce5be..fd61f71e 100644 --- a/contrib/ledger.vim +++ b/contrib/ledger.vim @@ -6,7 +6,7 @@ " Revision history " 2009-01-28 S.Karrmann: minor fixes " 2009-01-27 third version by S.Karrmann. -" better extraction of the amount of the transaction +" better extraction of the amount of the posting " decimal separator can be one of '.' and ','. " 2005-02-05 first version (partly copied from ledger.vim 0.0.1) @@ -19,7 +19,7 @@ endif " for debugging syntax clear -" region: a normal transaction +" region: a normal posting syn region transNorm start=/^\d/ skip=/^\s/ end=/^/ fold keepend transparent contains=transDate syn match transDate /^\d\S\+/ contained syn match Comment /^;.*$/ @@ -27,7 +27,7 @@ syn match Comment /^;.*$/ highlight default link Comment SpecialKey highlight default link transDate Question -" folding: how to represent a transaction in one line. +" folding: how to represent a posting in one line. function! LedgerFoldText() let line = strpart(getline(v:foldstart), 0, 99) " get the amount at the end of the second line @@ -48,7 +48,7 @@ endfunction set foldtext=LedgerFoldText() set foldmethod=syntax -" syncinc is easy: search for the first transaction. +" syncinc is easy: search for the first posting. syn sync clear syn sync match ledgerSync grouphere transNorm "^\d" |