From 31e8d3c1852b4873d4be98dfe056d4c23cb0fd51 Mon Sep 17 00:00:00 2001 From: vro Date: Tue, 10 Jul 2018 14:58:08 +0300 Subject: [PATCH] 0029940: The method TPrsStd_AISPresentation::SetSelectionMode() seems useless for transactions A boolean parameter is added with a default value to the method TPrsStd_AISPresentation::SetSelectionMode(). By default, behavior of the method is not changed. But if the parameter's value is changed to FALSE, change of selection mode for the object will not influence the transaction. In other words, the attribute will not set modified and will not put into transaction delta. This behavior suits the usual notion of the object in an application: the object has color, material, transparency, but selection mode is not a property of the object. It is a property of an operation involving the object. Therefore, it has sense to remove the method SetSelectionMode() from TPrsStd_AISPresentation. For a while, it is marked as obsolete. --- src/TDataXtd/TDataXtd_Presentation.cxx | 5 +++-- src/TDataXtd/TDataXtd_Presentation.hxx | 8 +++++++- src/TPrsStd/TPrsStd_AISPresentation.cxx | 7 ++++--- src/TPrsStd/TPrsStd_AISPresentation.hxx | 10 ++++++++-- 4 files changed, 22 insertions(+), 8 deletions(-) diff --git a/src/TDataXtd/TDataXtd_Presentation.cxx b/src/TDataXtd/TDataXtd_Presentation.cxx index 53d3d9fea6..b389e603c0 100644 --- a/src/TDataXtd/TDataXtd_Presentation.cxx +++ b/src/TDataXtd/TDataXtd_Presentation.cxx @@ -285,11 +285,12 @@ void TDataXtd_Presentation::SetMode(const Standard_Integer theMode) //function : SetSelectionMode //purpose : //======================================================================= -void TDataXtd_Presentation::SetSelectionMode(const Standard_Integer theSelectionMode) +void TDataXtd_Presentation::SetSelectionMode(const Standard_Integer theSelectionMode, const Standard_Boolean theTransaction) { if (! myHasOwnSelectionMode || mySelectionMode != theSelectionMode) { - Backup(); + if (theTransaction) + Backup(); mySelectionMode = theSelectionMode; myHasOwnSelectionMode = Standard_True; } diff --git a/src/TDataXtd/TDataXtd_Presentation.hxx b/src/TDataXtd/TDataXtd_Presentation.hxx index e92dc574ca..9911b2462e 100644 --- a/src/TDataXtd/TDataXtd_Presentation.hxx +++ b/src/TDataXtd/TDataXtd_Presentation.hxx @@ -114,7 +114,13 @@ public: Standard_EXPORT void SetMode(const Standard_Integer theMode); - Standard_EXPORT void SetSelectionMode(const Standard_Integer theSelectionMode); + //! Sets selection mode. + //! If "theTransaction" flag is OFF, modification of the attribute doesn't influence the transaction mechanism + //! (the attribute doesn't participate in undo/redo). + //! Certainly, if any other data of the attribute is modified (display mode, color, ...), + //! the attribute will be included into transaction. + //! Obsolete method (may be removed later). + Standard_EXPORT void SetSelectionMode(const Standard_Integer theSelectionMode, const Standard_Boolean theTransaction = Standard_True); Standard_EXPORT Standard_Integer MaterialIndex() const; diff --git a/src/TPrsStd/TPrsStd_AISPresentation.cxx b/src/TPrsStd/TPrsStd_AISPresentation.cxx index cc8d75f530..173639ab58 100644 --- a/src/TPrsStd/TPrsStd_AISPresentation.cxx +++ b/src/TPrsStd/TPrsStd_AISPresentation.cxx @@ -591,10 +591,11 @@ Standard_Boolean TPrsStd_AISPresentation::HasOwnSelectionMode() const //function : SetSelectionMode //purpose : //======================================================================= -void TPrsStd_AISPresentation::SetSelectionMode(const Standard_Integer theSelectionMode) +void TPrsStd_AISPresentation::SetSelectionMode(const Standard_Integer theSelectionMode, const Standard_Boolean theTransaction) { - Backup(); - getData()->SetSelectionMode (theSelectionMode); + if (theTransaction) + Backup(); + getData()->SetSelectionMode (theSelectionMode, theTransaction); if ( myAIS.IsNull() ) AISUpdate(); diff --git a/src/TPrsStd/TPrsStd_AISPresentation.hxx b/src/TPrsStd/TPrsStd_AISPresentation.hxx index e72b75982c..6d5ddd22df 100644 --- a/src/TPrsStd/TPrsStd_AISPresentation.hxx +++ b/src/TPrsStd/TPrsStd_AISPresentation.hxx @@ -157,8 +157,14 @@ public: Standard_EXPORT void UnsetMode(); Standard_EXPORT Standard_Integer SelectionMode() const; - - Standard_EXPORT void SetSelectionMode (const Standard_Integer theSelectionMode); + + //! Sets selection mode. + //! If "theTransaction" flag is OFF, modification of the attribute doesn't influence the transaction mechanism + //! (the attribute doesn't participate in undo/redo). + //! Certainly, if any other data of the attribute is modified (display mode, color, ...), + //! the attribute will be included into transaction. + //! Obsolete method (may be removed later). + Standard_EXPORT void SetSelectionMode (const Standard_Integer theSelectionMode, const Standard_Boolean theTransaction = Standard_True); Standard_EXPORT Standard_Boolean HasOwnSelectionMode() const;