/// The second set is the objects that causes this object is modified
std::map<std::shared_ptr<ModelAPI_Feature>, std::set<std::shared_ptr<ModelAPI_Feature> > >
myModified;
+ /// Features which arguments were modified by not-persistent changes.
+ /// So, these referencing arguments must be updated due to these features info also before execution).
+ std::map<std::shared_ptr<ModelAPI_Feature>, std::set<std::shared_ptr<ModelAPI_Feature> > >
+ myNotPersistentRefs;
/// features that must be additionally processed after execution of finish operation
std::set<std::shared_ptr<ModelAPI_Feature> > myWaitForFinish;
/// to know that some parameter was changed during this operation (to enable update expressions)
bool myIsProcessed;
/// set that contains features that must be executed only on finish of the operation
std::set<std::shared_ptr<ModelAPI_Feature> > myProcessOnFinish;
-
+ /// to avoid infinitive cycling: feature -> count of the processing periods during this update
+ std::map<std::shared_ptr<ModelAPI_Feature>, int > myProcessed;
+ /// if preview in hte property panel is blocked and any update is postponed until the end of operation
+ bool myIsPreviewBlocked;
public:
/// Is called only once, on startup of the application
const ModelAPI_ExecState theState);
/// On operation start/end/abort the "Just" fileds must be cleared and processed in the right way
- /// \param theFinish is true for start, close or abort transaction: all objects must be processed
- void processFeatures();
+ //! \param theFlushRedisplay a boolean value if the redisplay signal should be flushed
+ void processFeatures(const bool theFlushRedisplay = true);
/// Performs the feature execution
/// \returns the status of execution