diff options
author | Michael Muré <batolettre@gmail.com> | 2020-06-26 19:20:36 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-06-26 19:20:36 +0200 |
commit | 1e3dd82fd619f7b43b3193016232ef69f9707f42 (patch) | |
tree | 00e847500b34c6f9a721c71474993d1c08ae8fb1 /bug/clocks.go | |
parent | 2dd0dbb1344ae9293aae05346f977b5d5907934b (diff) | |
parent | 88ad7e606f1cbf9e47b968a208e3510f7f9a81c5 (diff) | |
download | git-bug-1e3dd82fd619f7b43b3193016232ef69f9707f42.tar.gz |
Merge pull request #411 from MichaelMure/repo-rework
Repository rework
Diffstat (limited to 'bug/clocks.go')
-rw-r--r-- | bug/clocks.go | 42 |
1 files changed, 26 insertions, 16 deletions
diff --git a/bug/clocks.go b/bug/clocks.go index 52d23544..ba93e0dc 100644 --- a/bug/clocks.go +++ b/bug/clocks.go @@ -4,24 +4,34 @@ import ( "github.com/MichaelMure/git-bug/repository" ) -// Witnesser will read all the available Bug to recreate the different logical -// clocks -func Witnesser(repo repository.ClockedRepo) error { - for b := range ReadAllLocalBugs(repo) { - if b.Err != nil { - return b.Err - } +// ClockLoader is the repository.ClockLoader for the Bug entity +var ClockLoader = repository.ClockLoader{ + Clocks: []string{creationClockName, editClockName}, + Witnesser: func(repo repository.ClockedRepo) error { + for b := range ReadAllLocalBugs(repo) { + if b.Err != nil { + return b.Err + } - err := repo.WitnessCreate(b.Bug.createTime) - if err != nil { - return err - } + createClock, err := repo.GetOrCreateClock(creationClockName) + if err != nil { + return err + } + err = createClock.Witness(b.Bug.createTime) + if err != nil { + return err + } - err = repo.WitnessEdit(b.Bug.editTime) - if err != nil { - return err + editClock, err := repo.GetOrCreateClock(editClockName) + if err != nil { + return err + } + err = editClock.Witness(b.Bug.editTime) + if err != nil { + return err + } } - } - return nil + return nil + }, } |