package bug import ( "fmt" "github.com/MichaelMure/git-bug/util/git" "github.com/MichaelMure/git-bug/util/text" ) // AddCommentOperation will add a new comment in the bug var _ Operation = AddCommentOperation{} type AddCommentOperation struct { *OpBase Message string `json:"message"` // TODO: change for a map[string]util.hash to store the filename ? Files []git.Hash `json:"files"` } func (op AddCommentOperation) base() *OpBase { return op.OpBase } func (op AddCommentOperation) Apply(snapshot Snapshot) Snapshot { comment := Comment{ Message: op.Message, Author: op.Author, Files: op.Files, UnixTime: op.UnixTime, } snapshot.Comments = append(snapshot.Comments, comment) return snapshot } func (op AddCommentOperation) GetFiles() []git.Hash { return op.Files } func (op AddCommentOperation) Validate() error { if err := opBaseValidate(op, AddCommentOp); err != nil { return err } if text.Empty(op.Message) { return fmt.Errorf("message is empty") } if !text.Safe(op.Message) { return fmt.Errorf("message is not fully printable") } return nil } func NewAddCommentOp(author Person, unixTime int64, message string, files []git.Hash) AddCommentOperation { return AddCommentOperation{ OpBase: newOpBase(AddCommentOp, author, unixTime), Message: message, Files: files, } } // Convenience function to apply the operation func AddComment(b Interface, author Person, unixTime int64, message string) error { return AddCommentWithFiles(b, author, unixTime, message, nil) } func AddCommentWithFiles(b Interface, author Person, unixTime int64, message string, files []git.Hash) error { addCommentOp := NewAddCommentOp(author, unixTime, message, files) if err := addCommentOp.Validate(); err != nil { return err } b.Append(addCommentOp) return nil }