diff options
author | Michael Muré <batolettre@gmail.com> | 2018-09-28 20:39:39 +0200 |
---|---|---|
committer | Michael Muré <batolettre@gmail.com> | 2018-09-29 00:51:54 +0200 |
commit | 1bf268cebc84a9de1e538cbb54bcc0f434022192 (patch) | |
tree | daeb92cd6b15d56a7a7102f95b73756e5b9597d0 /operations/set_title.go | |
parent | 8af6f7d98f2fd98f85d6a17bcda49983c272cf48 (diff) | |
download | git-bug-1bf268cebc84a9de1e538cbb54bcc0f434022192.tar.gz |
merge package operations into bug, they are tightly coupled anyway
Diffstat (limited to 'operations/set_title.go')
-rw-r--r-- | operations/set_title.go | 90 |
1 files changed, 0 insertions, 90 deletions
diff --git a/operations/set_title.go b/operations/set_title.go deleted file mode 100644 index e6964a65..00000000 --- a/operations/set_title.go +++ /dev/null @@ -1,90 +0,0 @@ -package operations - -import ( - "fmt" - "strings" - - "github.com/MichaelMure/git-bug/bug" - "github.com/MichaelMure/git-bug/util/text" -) - -// SetTitleOperation will change the title of a bug - -var _ bug.Operation = SetTitleOperation{} - -type SetTitleOperation struct { - *bug.OpBase - Title string `json:"title"` - Was string `json:"was"` -} - -func (op SetTitleOperation) Apply(snapshot bug.Snapshot) bug.Snapshot { - snapshot.Title = op.Title - - return snapshot -} - -func (op SetTitleOperation) Validate() error { - if err := bug.OpBaseValidate(op, bug.SetTitleOp); err != nil { - return err - } - - if text.Empty(op.Title) { - return fmt.Errorf("title is empty") - } - - if strings.Contains(op.Title, "\n") { - return fmt.Errorf("title should be a single line") - } - - if !text.Safe(op.Title) { - return fmt.Errorf("title should be fully printable") - } - - if strings.Contains(op.Was, "\n") { - return fmt.Errorf("previous title should be a single line") - } - - if !text.Safe(op.Was) { - return fmt.Errorf("previous title should be fully printable") - } - - return nil -} - -func NewSetTitleOp(author bug.Person, unixTime int64, title string, was string) SetTitleOperation { - return SetTitleOperation{ - OpBase: bug.NewOpBase(bug.SetTitleOp, author, unixTime), - Title: title, - Was: was, - } -} - -// Convenience function to apply the operation -func SetTitle(b bug.Interface, author bug.Person, unixTime int64, title string) error { - it := bug.NewOperationIterator(b) - - var lastTitleOp bug.Operation - for it.Next() { - op := it.Value() - if op.OpType() == bug.SetTitleOp { - lastTitleOp = op - } - } - - var was string - if lastTitleOp != nil { - was = lastTitleOp.(SetTitleOperation).Title - } else { - was = b.FirstOp().(CreateOperation).Title - } - - setTitleOp := NewSetTitleOp(author, unixTime, title, was) - - if err := setTitleOp.Validate(); err != nil { - return err - } - - b.Append(setTitleOp) - return nil -} |