aboutsummaryrefslogtreecommitdiff
path: root/yamldb/yamldb.go
diff options
context:
space:
mode:
Diffstat (limited to 'yamldb/yamldb.go')
-rw-r--r--yamldb/yamldb.go32
1 files changed, 16 insertions, 16 deletions
diff --git a/yamldb/yamldb.go b/yamldb/yamldb.go
index eec23be..1478cc7 100644
--- a/yamldb/yamldb.go
+++ b/yamldb/yamldb.go
@@ -18,9 +18,7 @@ type YamlDB struct {
// Transaction executes the given callback and safely saves
// the data after they are modified within the callback
-func (db *YamlDB) Transaction(callback func(), marshaller func() ([]byte, error)) error {
- var err error
-
+func (db *YamlDB) Transaction(callback func() bool, marshaller func() ([]byte, error)) error {
log.Debug("Enter transaction")
db.lock.Lock()
defer func() {
@@ -28,19 +26,21 @@ func (db *YamlDB) Transaction(callback func(), marshaller func() ([]byte, error)
log.Debug("Exit transaction")
}()
- callback()
-
- yamlData, err := marshaller()
- if err != nil {
- return errors.Wrap(err, "Data marshalling error")
- }
- err = ioutil.WriteFile(db.PathNew, yamlData, 0644)
- if err != nil {
- return errors.Wrap(err, "YamlDB write failure")
- }
- err = os.Rename(db.PathNew, db.Path)
- if err != nil {
- return errors.Wrap(err, "Couldn't rewrite an old YamlDB file")
+ isDataChanged := callback()
+
+ if isDataChanged {
+ yamlData, err := marshaller()
+ if err != nil {
+ return errors.Wrap(err, "Data marshalling error")
+ }
+ err = ioutil.WriteFile(db.PathNew, yamlData, 0644)
+ if err != nil {
+ return errors.Wrap(err, "YamlDB write failure")
+ }
+ err = os.Rename(db.PathNew, db.Path)
+ if err != nil {
+ return errors.Wrap(err, "Couldn't rewrite an old YamlDB file")
+ }
}
return nil