Krita Source Code Documentation
Loading...
Searching...
No Matches
KisNodeCompositeOpCommand Class Reference

The command for setting the composite op. More...

#include <kis_node_compositeop_command.h>

+ Inheritance diagram for KisNodeCompositeOpCommand:

Public Member Functions

bool canAnnihilateWith (const KUndo2Command *command) const override
 
bool canMergeWith (const KUndo2Command *command) const override
 
int id () const override
 
 KisNodeCompositeOpCommand (KisNodeSP node, const QString &newCompositeOp)
 
bool mergeWith (const KUndo2Command *command) override
 
void redo () override
 
void undo () override
 
- Public Member Functions inherited from KisNodeCommand
 KisNodeCommand (const KUndo2MagicString &name, KisNodeSP node)
 
 ~KisNodeCommand () override
 
- Public Member Functions inherited from KUndo2Command
QString actionText () const
 
const KUndo2Commandchild (int index) const
 
int childCount () const
 
virtual QTime endTime () const
 
KUndo2CommandExtraDataextraData () const
 
bool hasParent () const
 
virtual bool isMerged () const
 
 KUndo2Command (const KUndo2MagicString &text, KUndo2Command *parent=0)
 
 KUndo2Command (KUndo2Command *parent=0)
 
virtual QVector< KUndo2Command * > mergeCommandsVector () const
 
virtual void redoMergedCommands ()
 
void setEndTime ()
 
virtual void setEndTime (const QTime &time)
 
void setExtraData (KUndo2CommandExtraData *data)
 
void setText (const KUndo2MagicString &text)
 
void setTime ()
 
virtual void setTime (const QTime &time)
 
virtual void setTimedID (int timedID)
 
KUndo2MagicString text () const
 
virtual QTime time () const
 
virtual int timedId () const
 
virtual bool timedMergeWith (KUndo2Command *other)
 
virtual void undoMergedCommands ()
 
virtual ~KUndo2Command ()
 
- Public Member Functions inherited from KisAsynchronouslyMergeableCommandInterface
virtual ~KisAsynchronouslyMergeableCommandInterface ()
 

Private Member Functions

void setCompositeOpImpl (const QString &compositeOp)
 

Private Attributes

QString m_newCompositeOp
 
boost::optional< QString > m_oldCompositeOp
 

Additional Inherited Members

- Protected Attributes inherited from KisNodeCommand
KisNodeSP m_node
 

Detailed Description

The command for setting the composite op.

Definition at line 15 of file kis_node_compositeop_command.h.

Constructor & Destructor Documentation

◆ KisNodeCompositeOpCommand()

KisNodeCompositeOpCommand::KisNodeCompositeOpCommand ( KisNodeSP node,
const QString & newCompositeOp )

Constructor

Parameters
nodeThe node the command will be working on.
oldCompositeOpthe old node composite op
newCompositeOpthe new node composite op

Definition at line 14 of file kis_node_compositeop_command.cpp.

14 :
15 KisNodeCommand(kundo2_i18n("Composition Mode Change"), node)
16{
17 m_newCompositeOp = newCompositeOp;
18}
KisNodeCommand(const KUndo2MagicString &name, KisNodeSP node)
KUndo2MagicString kundo2_i18n(const char *text)

References m_newCompositeOp.

Member Function Documentation

◆ canAnnihilateWith()

bool KisNodeCompositeOpCommand::canAnnihilateWith ( const KUndo2Command * other) const
overridevirtual

Attempts to merge this command with command and checks if the two commands compensate each other. If the function returns true, both commands are removed from the stack.

If this function returns true, calling this command's redo() followed by other redo() must have no effect.

The function itself shouldn't do any changes to the command, because after returning true, the command will be deleted as a "noop"

KUndo2QStack will only try to merge two commands if they have the same id, and the id is not -1.

The default implementation returns false.

See also
id() KUndo2QStack::push()

Reimplemented from KUndo2Command.

Definition at line 76 of file kis_node_compositeop_command.cpp.

77{
78 const KisNodeCompositeOpCommand *other =
79 dynamic_cast<const KisNodeCompositeOpCommand*>(command);
80
81 if (!other || other->m_node != m_node) {
82 return false;
83 }
84
86 return *m_oldCompositeOp == other->m_newCompositeOp;
87}
The command for setting the composite op.
boost::optional< QString > m_oldCompositeOp
#define KIS_SAFE_ASSERT_RECOVER_RETURN_VALUE(cond, val)
Definition kis_assert.h:129

References KIS_SAFE_ASSERT_RECOVER_RETURN_VALUE, m_newCompositeOp, KisNodeCommand::m_node, and m_oldCompositeOp.

◆ canMergeWith()

bool KisNodeCompositeOpCommand::canMergeWith ( const KUndo2Command * command) const
overridevirtual
Returns
true if command can be merged with (*this) command using KUndo2Command::mergeWith() call.

WARNING: if canMergeWith() returned true, then mergeWith() must also return true. Otherwise KisSavedMacroCommand will be able to enter inconsistent state and assert.

Implements KisAsynchronouslyMergeableCommandInterface.

Definition at line 68 of file kis_node_compositeop_command.cpp.

69{
70 const KisNodeCompositeOpCommand *other =
71 dynamic_cast<const KisNodeCompositeOpCommand*>(command);
72
73 return other && other->m_node == m_node;
74}

References KisNodeCommand::m_node.

◆ id()

int KisNodeCompositeOpCommand::id ( ) const
overridevirtual

Returns the ID of this command.

A command ID is used in command compression. It must be an integer unique to this command's class, or -1 if the command doesn't support compression.

If the command supports compression this function must be overridden in the derived class to return the correct ID. The base implementation returns -1.

KUndo2QStack::push() will only try to merge two commands if they have the same ID, and the ID is not -1.

See also
mergeWith(), KUndo2QStack::push()

Reimplemented from KUndo2Command.

Definition at line 45 of file kis_node_compositeop_command.cpp.

References KisCommandUtils::ChangeNodeCompositeOpId.

◆ mergeWith()

bool KisNodeCompositeOpCommand::mergeWith ( const KUndo2Command * command)
overridevirtual

Attempts to merge this command with command. Returns true on success; otherwise returns false.

If this function returns true, calling this command's redo() must have the same effect as redoing both this command and command. Similarly, calling this command's undo() must have the same effect as undoing command and this command.

KUndo2QStack will only try to merge two commands if they have the same id, and the id is not -1.

The default implementation returns false.

See also
id() KUndo2QStack::push()

Reimplemented from KUndo2Command.

Definition at line 50 of file kis_node_compositeop_command.cpp.

51{
52 const KisNodeCompositeOpCommand *other =
53 dynamic_cast<const KisNodeCompositeOpCommand*>(command);
54
55 if (other && other->m_node == m_node) {
56 // verify both commands have been executed and they are consecutive
60
62 return true;
63 }
64
65 return false;
66}
#define KIS_SAFE_ASSERT_RECOVER_NOOP(cond)
Definition kis_assert.h:130

References KIS_SAFE_ASSERT_RECOVER_NOOP, m_newCompositeOp, KisNodeCommand::m_node, and m_oldCompositeOp.

◆ redo()

void KisNodeCompositeOpCommand::redo ( )
overridevirtual

Applies a change to the document. This function must be implemented in the derived class. Calling KUndo2QStack::push(), KUndo2QStack::undo() or KUndo2QStack::redo() from this function leads to undefined behavior.

The default implementation calls redo() on all child commands.

See also
undo()

Reimplemented from KUndo2Command.

Definition at line 31 of file kis_node_compositeop_command.cpp.

32{
33 if (!m_oldCompositeOp) {
35 }
37}
void setCompositeOpImpl(const QString &compositeOp)
const QString & compositeOpId() const

References KisBaseNode::compositeOpId(), m_newCompositeOp, KisNodeCommand::m_node, m_oldCompositeOp, and setCompositeOpImpl().

◆ setCompositeOpImpl()

void KisNodeCompositeOpCommand::setCompositeOpImpl ( const QString & compositeOp)
private

The node might have had "Destination Atop" blending that changes extent of the layer

Definition at line 20 of file kis_node_compositeop_command.cpp.

21{
26 const QRect oldExtent = m_node->extent();
27 m_node->setCompositeOpId(compositeOp);
28 m_node->setDirty(oldExtent | m_node->extent());
29}
virtual QRect extent() const
void setCompositeOpId(const QString &compositeOpId)
virtual void setDirty()
Definition kis_node.cpp:577

References KisBaseNode::extent(), KisNodeCommand::m_node, KisBaseNode::setCompositeOpId(), and KisNode::setDirty().

◆ undo()

void KisNodeCompositeOpCommand::undo ( )
overridevirtual

Reverts a change to the document. After undo() is called, the state of the document should be the same as before redo() was called. This function must be implemented in the derived class. Calling KUndo2QStack::push(), KUndo2QStack::undo() or KUndo2QStack::redo() from this function leads to undefined behavior.

The default implementation calls undo() on all child commands in reverse order.

See also
redo()

Reimplemented from KUndo2Command.

Definition at line 39 of file kis_node_compositeop_command.cpp.

References KIS_SAFE_ASSERT_RECOVER_RETURN, m_oldCompositeOp, and setCompositeOpImpl().

Member Data Documentation

◆ m_newCompositeOp

QString KisNodeCompositeOpCommand::m_newCompositeOp
private

Definition at line 41 of file kis_node_compositeop_command.h.

◆ m_oldCompositeOp

boost::optional<QString> KisNodeCompositeOpCommand::m_oldCompositeOp
private

Definition at line 40 of file kis_node_compositeop_command.h.


The documentation for this class was generated from the following files: