LibrePCB Developers Documentation
CmdCombineBoardNetSegments Class Referencefinal

This undo command combines two board netsegments together. More...

#include <cmdcombineboardnetsegments.h>

+ Inheritance diagram for CmdCombineBoardNetSegments:
+ Collaboration diagram for CmdCombineBoardNetSegments:

Public Member Functions

 CmdCombineBoardNetSegments ()=delete
 
 CmdCombineBoardNetSegments (const CmdCombineBoardNetSegments &other)=delete
 
 CmdCombineBoardNetSegments (BI_NetSegment &toBeRemoved, BI_NetLineAnchor &oldAnchor, BI_NetSegment &result, BI_NetLineAnchor &newAnchor) noexcept
 
 ~CmdCombineBoardNetSegments () noexcept
 
CmdCombineBoardNetSegmentsoperator= (const CmdCombineBoardNetSegments &rhs)=delete
 
- Public Member Functions inherited from UndoCommandGroup
 UndoCommandGroup ()=delete
 
 UndoCommandGroup (const UndoCommandGroup &other)=delete
 
 UndoCommandGroup (const QString &text) noexcept
 
virtual ~UndoCommandGroup () noexcept
 
int getChildCount () const noexcept
 
bool appendChild (UndoCommand *cmd)
 Append a new command to the list of child commands. More...
 
UndoCommandGroupoperator= (const UndoCommandGroup &rhs)=delete
 
- Public Member Functions inherited from UndoCommand
 UndoCommand ()=delete
 
 UndoCommand (const UndoCommand &other)=delete
 
 UndoCommand (const QString &text) noexcept
 
virtual ~UndoCommand () noexcept
 
const QString & getText () const noexcept
 
bool wasEverExecuted () const noexcept
 This method shows whether that command was ever executed (execute() called successfully) More...
 
bool wasEverReverted () const noexcept
 This method shows whether that command was ever reverted (undo() called at least one time) More...
 
bool isCurrentlyExecuted () const noexcept
 This method shows whether that command is currently executed (redo() called one time more than undo()) More...
 
virtual bool execute () final
 Execute the command (must only be called once) More...
 
virtual void undo () final
 Undo the command. More...
 
virtual void redo () final
 Redo the command. More...
 
UndoCommandoperator= (const UndoCommand &rhs)=delete
 

Private Member Functions

bool performExecute () override
 Execute the command the first time. More...
 

Private Attributes

BI_NetSegmentmOldSegment
 
BI_NetSegmentmNewSegment
 
BI_NetLineAnchormOldAnchor
 
BI_NetLineAnchormNewAnchor
 

Additional Inherited Members

- Protected Member Functions inherited from UndoCommandGroup
virtual bool performExecute () override
 Execute the command the first time. More...
 
virtual void performUndo () override
 Undo the command. More...
 
virtual void performRedo () override
 Redo the command. More...
 
virtual void performPostExecution () noexcept
 Perform custom actions after modifying the undo stack state. More...
 
void execNewChildCmd (UndoCommand *cmd)
 Helper method for derived classes to execute and add new child commands. More...
 
virtual bool performExecute ()=0
 Execute the command the first time. More...
 
virtual void performUndo ()=0
 Undo the command. More...
 
virtual void performRedo ()=0
 Redo the command. More...
 

Detailed Description

This undo command combines two board netsegments together.

Note
Both netsegments must have the same netsignal!

Constructor & Destructor Documentation

◆ CmdCombineBoardNetSegments() [1/3]

◆ CmdCombineBoardNetSegments() [2/3]

◆ CmdCombineBoardNetSegments() [3/3]

CmdCombineBoardNetSegments ( BI_NetSegment toBeRemoved,
BI_NetLineAnchor oldAnchor,
BI_NetSegment result,
BI_NetLineAnchor newAnchor 
)
noexcept

◆ ~CmdCombineBoardNetSegments()

Member Function Documentation

◆ operator=()

CmdCombineBoardNetSegments & operator= ( const CmdCombineBoardNetSegments rhs)
delete

◆ performExecute()

bool performExecute ( )
overrideprivatevirtual

Execute the command the first time.

Note
This method must be implemented in all derived classes. If the first time execution is exactly identical to an "redo" action, you can simple call librepcb::editor::UndoCommand::performRedo() in the implementation of this method.
Return values
trueIf the command has done some changes
falseIf the command has done nothing (the command can be deleted)

Reimplemented from UndoCommandGroup.

+ Here is the call graph for this function:

Member Data Documentation

◆ mOldSegment

BI_NetSegment& mOldSegment
private

◆ mNewSegment

BI_NetSegment& mNewSegment
private

◆ mOldAnchor

BI_NetLineAnchor& mOldAnchor
private

◆ mNewAnchor

BI_NetLineAnchor& mNewAnchor
private

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