Base::SequencerLauncher Class Reference

The SequencerLauncher class is provided for convenience. More...

#include <Sequencer.h>

Public Member Functions

bool next (bool canAbort=false)
 
size_t numberOfSteps () const
 
 SequencerLauncher (const char *pszStr, size_t steps)
 
void setProgress (size_t)
 
void setText (const char *pszTxt)
 
bool wasCanceled () const
 
 ~SequencerLauncher ()
 

Detailed Description

The SequencerLauncher class is provided for convenience.

It allows you to run an instance of the sequencer by instantiating an object of this class – most suitable on the stack. So this mechanism can be used for try-catch-blocks to destroy the object automatically if the C++ exception mechanism cleans up the stack.

This class has been introduced to simplify the use with the sequencer. In the FreeCAD Gui layer there is a subclass of SequencerBase called ProgressBar that grabs the keyboard and filters most of the incoming events. If the programmer uses the API of SequencerBase directly to start an instance without due diligence with exceptions then a not handled exception could block the whole application – the user has to kill the application then.

Below is an example of a not correctly used sequencer.

#include <Base/Sequencer.h>
void runOperation();
void myTest()
{
try{
runOperation();
} catch(...) {
// the programmer forgot to stop the sequencer here
// Under circumstances the sequencer never gets stopped so the keyboard never gets ungrabbed and
// all Gui events still gets filtered.
}
}
void runOperation()
{
Base::Sequencer().start ("my text", 10);
for (int i=0; i<10; i++)
{
// do something where an exception be thrown
...
}
}

To avoid such problems the SequencerLauncher class can be used as follows:

#include <Base/Sequencer.h>
void runOperation();
void myTest()
{
try{
runOperation();
} catch(...) {
// the programmer forgot to halt the sequencer here
// If SequencerLauncher leaves its scope the object gets destructed automatically and
// stops the running sequencer.
}
}
void runOperation()
{
// create an instance on the stack (not on any terms on the heap)
SequencerLauncher seq("my text", 10);
for (int i=0; i<10; i++)
{
// do something (e.g. here can be thrown an exception)
...
seq.next ();
}
}
Author
Werner Mayer

Constructor & Destructor Documentation

◆ SequencerLauncher()

SequencerLauncher::SequencerLauncher ( const char *  pszStr,
size_t  steps 
)

◆ ~SequencerLauncher()

SequencerLauncher::~SequencerLauncher ( )

Member Function Documentation

◆ next()

bool SequencerLauncher::next ( bool  canAbort = false)

References Base::SequencerBase::Instance(), Base::SequencerP::mutex, and Base::SequencerBase::next().

Referenced by CmdTestProgress1::activated(), CmdTestProgress2::activated(), CmdTestProgress3::activated(), CmdTestProgress4::activated(), PartGui::CrossSections::apply(), Reen::BSplineParameterCorrection::CalcFirstSmoothMatrix(), Reen::BSplineParameterCorrection::CalcSecondSmoothMatrix(), Reen::BSplineParameterCorrection::CalcThirdSmoothMatrix(), MeshCore::MeshTrimming::CheckFacets(), MeshCore::MeshAlgorithm::CheckFacets(), MeshCore::MeshCurvature::ComputePerFace(), Reen::BSplineParameterCorrection::DoParameterCorrection(), MeshCore::MeshEvalTopology::Evaluate(), MeshCore::MeshEvalSelfIntersection::Evaluate(), MeshCore::MeshEvalNeighbourhood::Evaluate(), Robot::Edge2TracObject::execute(), Inspection::Feature::execute(), MeshCore::MeshAlgorithm::GetFacetsFromToolMesh(), MeshCore::MeshEvalNeighbourhood::GetIndices(), MeshCore::MeshEvalSelfIntersection::GetIntersections(), Part::ImportIgesParts(), Points::PointsAlgos::LoadAscii(), MeshCore::MeshInput::LoadInventor(), MeshPart::CurveProjectorWithToolMesh::makeToolMesh(), App::Application::openDocuments(), MeshPart::CurveProjectorSimple::projectCurve(), MeshPart::MeshProjection::projectEdgeToEdge(), MeshPart::MeshProjection::projectOnMesh(), MeshPart::MeshProjection::projectParallelToMesh(), MeshPart::MeshProjection::projectToMesh(), Base::XMLReader::readFiles(), App::Document::recompute(), Sandbox::WorkerThread::run(), BarThread::run(), MeshCore::MeshOutput::SaveAsciiSTL(), MeshCore::MeshOutput::SaveBinarySTL(), MeshCore::MeshOutput::SaveInventor(), MeshCore::MeshOutput::SaveNastran(), MeshCore::MeshOutput::SaveOBJ(), MeshCore::MeshOutput::SaveOFF(), MeshCore::MeshOutput::SaveSMF(), MeshCore::MeshOutput::SaveVRML(), MeshCore::MeshTrimming::TrimFacets(), Raytracing::LuxTools::writeShape(), Raytracing::PovTools::writeShape(), and Raytracing::PovTools::writeShapeCSV().

◆ numberOfSteps()

size_t SequencerLauncher::numberOfSteps ( ) const

◆ setProgress()

void SequencerLauncher::setProgress ( size_t  pos)

◆ setText()

void SequencerLauncher::setText ( const char *  pszTxt)

◆ wasCanceled()

bool SequencerLauncher::wasCanceled ( ) const

The documentation for this class was generated from the following files:
  • src/Base/Sequencer.h
  • src/Base/Sequencer.cpp
bool start(const char *pszStr, size_t steps)
Starts a new operation, returns false if there is already a pending operation, otherwise it returns t...
Definition: Sequencer.cpp:94
bool next(bool canAbort=false)
Performs the next step and returns true if the operation is not yet finished.
Definition: Sequencer.cpp:121
int i
Definition: SplineSurface.py:40
bool stop()
Stops the sequencer if all operations are finished.
Definition: Sequencer.cpp:147
SequencerBase & Sequencer()
Access to the only SequencerBase instance.
Definition: Sequencer.h:400
SequencerLauncher(const char *pszStr, size_t steps)
Definition: Sequencer.cpp:261