18#ifndef QGSPROCESSINGCONTEXT_H
19#define QGSPROCESSINGCONTEXT_H
53 Q_DECLARE_FLAGS( Flags, Flag )
73 mFlags = other.mFlags;
74 mProject = other.mProject;
75 mTransformContext = other.mTransformContext;
76 mExpressionContext = other.mExpressionContext;
78 mInvalidGeometryCallback = other.mInvalidGeometryCallback;
79 mUseDefaultInvalidGeometryCallback = other.mUseDefaultInvalidGeometryCallback;
80 mInvalidGeometryCheck = other.mInvalidGeometryCheck;
81 mTransformErrorCallback = other.mTransformErrorCallback;
82 mDefaultEncoding = other.mDefaultEncoding;
83 mFeedback = other.mFeedback;
84 mPreferredVectorFormat = other.mPreferredVectorFormat;
85 mPreferredRasterFormat = other.mPreferredRasterFormat;
86 mEllipsoid = other.mEllipsoid;
87 mDistanceUnit = other.mDistanceUnit;
88 mAreaUnit = other.mAreaUnit;
89 mLogLevel = other.mLogLevel;
90 mTemporaryFolderOverride = other.mTemporaryFolderOverride;
91 mMaximumThreads = other.mMaximumThreads;
125 mTransformContext = mProject->transformContext();
126 if ( mEllipsoid.isEmpty() )
127 mEllipsoid = mProject->ellipsoid();
129 mDistanceUnit = mProject->distanceUnits();
131 mAreaUnit = mProject->areaUnits();
182 void setEllipsoid( const QString &ellipsoid )
SIP_HOLDGIL;
259 , outputName( outputName )
260 , layerTypeHint( layerTypeHint )
280 bool forceName =
false;
301 int layerSortKey = 0;
332 void setOutputLayerName(
QgsMapLayer *layer )
const;
353 return mLayersToLoadOnCompletion;
367 return mLayersToLoadOnCompletion.contains( layer );
377 void setLayersToLoadOnCompletion(
const QMap< QString, QgsProcessingContext::LayerDetails > &layers )
SIP_HOLDGIL;
404 return mLayersToLoadOnCompletion[ layer ];
430 void setInvalidGeometryCallback( SIP_PYCALLABLE / AllowNone / );
432 Py_BEGIN_ALLOW_THREADS
434 sipCpp->setInvalidGeometryCallback( [a0](
const QgsFeature &arg )
437 Py_XDECREF( sipCallMethod( NULL, a0,
"D", &arg, sipType_QgsFeature, NULL ) );
469 void setTransformErrorCallback( SIP_PYCALLABLE / AllowNone / );
471 Py_BEGIN_ALLOW_THREADS
473 sipCpp->setTransformErrorCallback( [a0](
const QgsFeature &arg )
476 Py_XDECREF( sipCallMethod( NULL, a0,
"D", &arg, sipType_QgsFeature, NULL ) );
535 Q_ASSERT_X( QThread::currentThread() ==
QgsProcessingContext::thread(),
"QgsProcessingContext::pushToThread",
"Cannot push context to another thread unless the current thread matches the existing context thread affinity" );
536 tempLayerStore.moveToThread( thread );
558 QgsMapLayer *getMapLayer(
const QString &identifier );
680 void setTemporaryFolder( const QString &folder )
SIP_HOLDGIL;
726 IncludeProjectPath = 1 << 0,
728 Q_DECLARE_FLAGS( ProcessArgumentFlags, ProcessArgumentFlag )
735 QStringList asQgisProcessArguments( QgsProcessingContext::ProcessArgumentFlags flags = QgsProcessingContext::ProcessArgumentFlags() )
const;
739 QgsProcessingContext::Flags mFlags = QgsProcessingContext::Flags();
740 QPointer< QgsProject > mProject;
754 bool mUseDefaultInvalidGeometryCallback =
true;
755 std::function< void(
const QgsFeature & ) > mInvalidGeometryCallback;
757 std::function< void(
const QgsFeature & ) > mTransformErrorCallback;
758 QString mDefaultEncoding;
759 QMap< QString, LayerDetails > mLayersToLoadOnCompletion;
761 QPointer< QgsProcessingFeedback > mFeedback;
763 QString mPreferredVectorFormat;
764 QString mPreferredRasterFormat;
768 QString mTemporaryFolderOverride;
769 int mMaximumThreads = QThread::idealThreadCount();
The Qgis class provides global constants for use throughout the application.
DistanceUnit
Units of distance.
@ Unknown
Unknown distance unit.
@ Unknown
Unknown areal unit.
InvalidGeometryCheck
Methods for handling of features with invalid geometries.
@ NoCheck
No invalid geometry checking.
ProcessingLogLevel
Logging level for algorithms to use when pushing feedback messages.
@ DefaultLevel
Default logging level.
Contains information about the context in which a coordinate transform is executed.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
void setLoadedLayerStore(QgsMapLayerStore *store)
Sets the destination layer store for any layers loaded during expression evaluation.
An interface for objects which provide features via a getFeatures method.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
A storage object for map layers, in which the layers are owned by the store and have their lifetime b...
Base class for all map layer types.
Details for layers to load into projects.
QString groupName
Optional name for a layer tree group under which to place the layer when loading it into a project.
LayerDetails()=default
Default constructor.
QString name
Friendly name for layer, possibly for use when loading layer into project.
LayerDetails(const QString &name, QgsProject *project, const QString &outputName=QString(), QgsProcessingUtils::LayerHint layerTypeHint=QgsProcessingUtils::LayerHint::UnknownType)
Constructor for LayerDetails.
QString outputName
Associated output name from algorithm which generated the layer.
Contains information about the context in which a processing algorithm is executed.
QString defaultEncoding() const
Returns the default encoding to use for newly created files.
QThread * thread()
Returns the thread in which the context lives.
QgsProcessingContext::LayerDetails & layerToLoadOnCompletionDetails(const QString &layer)
Returns a reference to the details for a given layer which is loaded on completion of the algorithm o...
QgsProcessingFeedback * feedback()
Returns the associated feedback object.
QString preferredRasterFormat() const
Returns the preferred raster format to use for vector outputs.
QgsProcessingContext::Flags flags() const
Returns any flags set in the context.
ProcessArgumentFlag
Flags controlling the results given by asQgisProcessArguments().
QgsExpressionContext & expressionContext()
Returns the expression context.
QgsCoordinateTransformContext transformContext() const
Returns the coordinate transform context.
const QgsExpressionContext & expressionContext() const
Returns the expression context.
QgsProcessingContext(const QgsProcessingContext &other)=delete
QgsProcessingContext cannot be copied.
void setDefaultEncoding(const QString &encoding)
Sets the default encoding to use for newly created files.
void setFeedback(QgsProcessingFeedback *feedback)
Sets an associated feedback object.
void setFlags(QgsProcessingContext::Flags flags)
Sets flags for the context.
void setProject(QgsProject *project)
Sets the project in which the algorithm will be executed.
QgsProject * project() const
Returns the project in which the algorithm is being executed.
QMap< QString, QgsProcessingContext::LayerDetails > layersToLoadOnCompletion() const
Returns a map of layers (by ID or datasource) to LayerDetails, to load into the canvas upon completio...
void pushToThread(QThread *thread)
Pushes the thread affinity for the context (including all layers contained in the temporaryLayerStore...
Flag
Flags that affect how processing algorithms are run.
Qgis::InvalidGeometryCheck invalidGeometryCheck() const
Returns the behavior used for checking invalid geometries in input layers.
bool willLoadLayerOnCompletion(const QString &layer) const
Returns true if the given layer (by ID or datasource) will be loaded into the current project upon co...
void copyThreadSafeSettings(const QgsProcessingContext &other)
Copies all settings which are safe for use across different threads from other to this context.
void setInvalidGeometryCallback(const std::function< void(const QgsFeature &) > &callback)
Sets a callback function to use when encountering an invalid geometry and invalidGeometryCheck() is s...
void setPreferredVectorFormat(const QString &format)
Sets the preferred vector format to use for vector outputs.
void setTransformContext(const QgsCoordinateTransformContext &context)
Sets the coordinate transform context.
QgsProcessingContext & operator=(const QgsProcessingContext &other)=delete
QgsProcessingContext cannot be copied.
void setTransformErrorCallback(const std::function< void(const QgsFeature &) > &callback)
Sets a callback function to use when encountering a transform error when iterating features.
QString preferredVectorFormat() const
Returns the preferred vector format to use for vector outputs.
std::function< void(const QgsFeature &) > transformErrorCallback() const
Returns the callback function to use when encountering a transform error when iterating features.
void setPreferredRasterFormat(const QString &format)
Sets the preferred raster format to use for vector outputs.
Base class for providing feedback from a processing algorithm.
An interface for layer post-processing handlers for execution following a processing algorithm operat...
virtual ~QgsProcessingLayerPostProcessorInterface()=default
virtual void postProcessLayer(QgsMapLayer *layer, QgsProcessingContext &context, QgsProcessingFeedback *feedback)=0
Post-processes the specified layer, following successful execution of a processing algorithm.
LayerHint
Layer type hints.
@ UnknownType
Unknown layer type.
Encapsulates a QGIS project, including sets of map layers and their styles, layouts,...
#define SIP_ENUM_BASETYPE(type)
Q_DECLARE_OPERATORS_FOR_FLAGS(QgsTextRendererUtils::CurvedTextFlags)