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

#include <KisChangeCloneLayersCommand.h>

+ Inheritance diagram for KisChangeCloneLayersCommand:

Classes

struct  Private
 

Public Member Functions

 KisChangeCloneLayersCommand (QList< KisCloneLayerSP > cloneLayers, KisLayerSP newSource, KUndo2Command *parent=0)
 
bool mergeWith (const KUndo2Command *) override
 
void redo () override
 
void undo () override
 
- Public Member Functions inherited from KUndo2Command
QString actionText () const
 
virtual bool canAnnihilateWith (const KUndo2Command *other) const
 
const KUndo2Commandchild (int index) const
 
int childCount () const
 
virtual QTime endTime () const
 
KUndo2CommandExtraDataextraData () const
 
bool hasParent () const
 
virtual int id () 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 ()
 

Private Attributes

QScopedPointer< Privated
 

Detailed Description

Definition at line 14 of file KisChangeCloneLayersCommand.h.

Constructor & Destructor Documentation

◆ KisChangeCloneLayersCommand()

KisChangeCloneLayersCommand::KisChangeCloneLayersCommand ( QList< KisCloneLayerSP > cloneLayers,
KisLayerSP newSource,
KUndo2Command * parent = 0 )

Definition at line 18 of file KisChangeCloneLayersCommand.cpp.

19 : KUndo2Command(kundo2_i18n("Change Clone Layers"), parent)
20 , d(new Private())
21{
22 KIS_SAFE_ASSERT_RECOVER_RETURN(!cloneLayers.isEmpty());
23 d->cloneLayers = cloneLayers;
24 Q_FOREACH (KisCloneLayerSP layer, d->cloneLayers) {
25 d->originalSource << layer->copyFrom();
26 }
27 d->newSource = newSource;
28}
KUndo2Command(KUndo2Command *parent=0)
#define KIS_SAFE_ASSERT_RECOVER_RETURN(cond)
Definition kis_assert.h:128
KUndo2MagicString kundo2_i18n(const char *text)

References d, and KIS_SAFE_ASSERT_RECOVER_RETURN.

Member Function Documentation

◆ mergeWith()

bool KisChangeCloneLayersCommand::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 48 of file KisChangeCloneLayersCommand.cpp.

49{
50 const KisChangeCloneLayersCommand *other = dynamic_cast<const KisChangeCloneLayersCommand *>(command);
51
52 if (other && d->cloneLayers == other->d->cloneLayers) {
53 d->newSource = other->d->newSource;
54 return true;
55 }
56
57 return false;
58}

References d.

◆ redo()

void KisChangeCloneLayersCommand::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 30 of file KisChangeCloneLayersCommand.cpp.

31{
32 Q_FOREACH (KisCloneLayerSP layer, d->cloneLayers) {
33 layer->setCopyFrom(d->newSource);
34 layer->setDirty();
35 }
36}

References d.

◆ undo()

void KisChangeCloneLayersCommand::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 38 of file KisChangeCloneLayersCommand.cpp.

39{
40 KIS_SAFE_ASSERT_RECOVER_RETURN(d->cloneLayers.size() == d->originalSource.size());
41 for (int i = 0; i < d->cloneLayers.size(); ++i) {
42 KisCloneLayerSP layer = d->cloneLayers.at(i);
43 layer->setCopyFrom(d->originalSource.at(i));
44 layer->setDirty();
45 }
46}

References d, and KIS_SAFE_ASSERT_RECOVER_RETURN.

Member Data Documentation

◆ d

QScopedPointer<Private> KisChangeCloneLayersCommand::d
private

Definition at line 26 of file KisChangeCloneLayersCommand.h.


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