This commit is contained in:
@@ -10,4 +10,4 @@ go run . http -http=:8081 \
|
|||||||
-like-name '(AssetAccount|Retirement)' \
|
-like-name '(AssetAccount|Retirement)' \
|
||||||
-bpi ./http/bpi.dat \
|
-bpi ./http/bpi.dat \
|
||||||
"$@" \
|
"$@" \
|
||||||
./http/macro.d/*
|
./http/macro.d/
|
||||||
|
|||||||
@@ -3,7 +3,9 @@ package ledger
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
|
"io/fs"
|
||||||
"os"
|
"os"
|
||||||
|
"path/filepath"
|
||||||
"sort"
|
"sort"
|
||||||
"unicode"
|
"unicode"
|
||||||
)
|
)
|
||||||
@@ -18,6 +20,28 @@ func NewFiles(p string, q ...string) (Files, error) {
|
|||||||
return f, err
|
return f, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (files Files) paths() []string {
|
||||||
|
result := make([]string, 0, len(files))
|
||||||
|
for i := range files {
|
||||||
|
if info, err := os.Stat(files[i]); err == nil && info.IsDir() {
|
||||||
|
if err := filepath.WalkDir(files[i], func(p string, d fs.DirEntry, err error) error {
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if !d.IsDir() {
|
||||||
|
result = append(result, p)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
result = append(result, files[i])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
||||||
func (files Files) Add(payee string, delta Delta) error {
|
func (files Files) Add(payee string, delta Delta) error {
|
||||||
currencyValue := fmt.Sprintf("%s%.2f", delta.Currency, delta.Value)
|
currencyValue := fmt.Sprintf("%s%.2f", delta.Currency, delta.Value)
|
||||||
if delta.Currency != USD {
|
if delta.Currency != USD {
|
||||||
@@ -35,7 +59,7 @@ func (files Files) append(s string) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
f, err := os.OpenFile(string(files[0]), os.O_APPEND|os.O_CREATE|os.O_WRONLY, os.ModePerm)
|
f, err := os.OpenFile(string(files.paths()[0]), os.O_APPEND|os.O_CREATE|os.O_WRONLY, os.ModePerm)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -54,7 +78,7 @@ func (files Files) trimTrainlingWhitespace() error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
f, err := os.OpenFile(string(files[0]), os.O_CREATE|os.O_WRONLY, os.ModePerm)
|
f, err := os.OpenFile(string(files.paths()[0]), os.O_CREATE|os.O_WRONLY, os.ModePerm)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -64,7 +88,7 @@ func (files Files) trimTrainlingWhitespace() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (files Files) _lastNonWhitespacePos() (int, error) {
|
func (files Files) _lastNonWhitespacePos() (int, error) {
|
||||||
f, err := os.Open(string(files[0]))
|
f, err := os.Open(string(files.paths()[0]))
|
||||||
if os.IsNotExist(err) {
|
if os.IsNotExist(err) {
|
||||||
return -1, nil
|
return -1, nil
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -275,3 +275,18 @@ func TestFileDeltas(t *testing.T) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestFilesOfDir(t *testing.T) {
|
||||||
|
d := t.TempDir()
|
||||||
|
files := Files([]string{d, "/dev/null"})
|
||||||
|
if paths := files.paths(); len(paths) != 1 {
|
||||||
|
t.Error(paths)
|
||||||
|
}
|
||||||
|
|
||||||
|
os.WriteFile(path.Join(d, "1"), []byte{}, os.ModePerm)
|
||||||
|
os.Mkdir(path.Join(d, "d2"), os.ModePerm)
|
||||||
|
os.WriteFile(path.Join(d, "d2", "2"), []byte{}, os.ModePerm)
|
||||||
|
if paths := files.paths(); len(paths) != 3 || paths[0] != path.Join(d, "1") || paths[1] != path.Join(d, "d2", "2") {
|
||||||
|
t.Error(paths)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -35,8 +35,8 @@ func (t transactionRecipient) empty() bool {
|
|||||||
|
|
||||||
func (files Files) transactions() ([]transaction, error) {
|
func (files Files) transactions() ([]transaction, error) {
|
||||||
result := make([]transaction, 0)
|
result := make([]transaction, 0)
|
||||||
for i := range files {
|
for _, path := range files.paths() {
|
||||||
some, err := files._transactions(files[i])
|
some, err := files._transactions(path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user