Compare commits
2 Commits
d093db1a2b
...
768ce8e92e
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
768ce8e92e | ||
|
|
757afa603e |
@@ -97,7 +97,7 @@ func Main() {
|
||||
transactions := deltas.Transactions()
|
||||
|
||||
for i, transaction := range transactions {
|
||||
balances := ledger.Deltas(transaction).Like(q).Group(group).Balances().WithBPIs(bpis)
|
||||
balances := ledger.Deltas(transaction).Like(q).Group(group).Balances().WithBPIsAt(bpis, transaction[0].Date).Nonzero()
|
||||
shouldPrint := false
|
||||
shouldPrint = shouldPrint || len(balances) > 2
|
||||
if config.Query.NoExchanging {
|
||||
@@ -110,7 +110,7 @@ func Main() {
|
||||
}
|
||||
if shouldPrint {
|
||||
fmt.Printf("%s\t%s\n", transaction[0].Date, transaction[0].Description)
|
||||
FPrintBalances(os.Stdout, "\t\t", balances, transactions[:i+1].Deltas().Like(q).Group(group).Balances())
|
||||
FPrintBalances(os.Stdout, "\t\t", balances, transactions[:i+1].Deltas().Like(q).Group(group).Balances().WithBPIsAt(bpis, transaction[0].Date).Nonzero())
|
||||
}
|
||||
}
|
||||
default:
|
||||
|
||||
@@ -157,7 +157,7 @@ func (balances Balances) WithBPIsAt(bpis BPIs, date string) Balances {
|
||||
if k2 == USD {
|
||||
result[k][USD] = result[k][USD] + v2
|
||||
} else if scalar := bpis[k2].Lookup(date); scalar != nil {
|
||||
result[k][USD] = result[k][USD] + *scalar*v2
|
||||
result[k][USD] = result[k][USD] + v2*(*scalar)
|
||||
} else {
|
||||
result[k][k2] = result[k][k2] + v2
|
||||
}
|
||||
|
||||
@@ -57,10 +57,7 @@ func (deltas Deltas) Balances() Balances {
|
||||
}
|
||||
result[delta.Name][delta.Currency] += delta.Value
|
||||
if result[delta.Name][delta.Currency] < 0.000000001 && result[delta.Name][delta.Currency] > -0.000000001 {
|
||||
delete(result[delta.Name], delta.Currency)
|
||||
if len(result[delta.Name]) == 0 {
|
||||
delete(result, delta.Name)
|
||||
}
|
||||
result[delta.Name][delta.Currency] = 0
|
||||
}
|
||||
}
|
||||
return result
|
||||
|
||||
@@ -38,9 +38,12 @@ func TestDeltas(t *testing.T) {
|
||||
}
|
||||
|
||||
balances := deltas.Balances()
|
||||
if len(balances) != 1 {
|
||||
if len(balances) != 2 {
|
||||
t.Error(len(balances), balances)
|
||||
}
|
||||
if balances["a"][""] != 0 {
|
||||
t.Error(balances["a"])
|
||||
}
|
||||
if balances["b"][""] != 1.3 {
|
||||
t.Error(balances["b"])
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user