1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

0033246: Data Exchange, DE Wrapper - Checking license leads to performance problem

ReWork UpdateLoad functionality:
UpdateLoad calls only if provider is found.
UpdateLoad calls only for chosen type of translation (read/write)
Add new method to UpdateLoad all registered nodes.
This commit is contained in:
dpasukhi 2022-12-02 09:14:38 +00:00 committed by Vadim Glukhikh
parent 74cb5673a5
commit 669e0dfc17
13 changed files with 56 additions and 43 deletions

View File

@ -88,8 +88,11 @@ bool DE_ConfigurationNode::Save(const TCollection_AsciiString& theResourcePath)
// function : UpdateLoad // function : UpdateLoad
// purpose : // purpose :
//======================================================================= //=======================================================================
bool DE_ConfigurationNode::UpdateLoad() bool DE_ConfigurationNode::UpdateLoad(const Standard_Boolean theToImport,
const Standard_Boolean theToKeep)
{ {
(void)theToImport;
(void)theToKeep;
return true; return true;
} }

View File

@ -85,9 +85,12 @@ public:
//! @return new object with the same field values //! @return new object with the same field values
Standard_EXPORT virtual Handle(DE_ConfigurationNode) Copy() const = 0; Standard_EXPORT virtual Handle(DE_ConfigurationNode) Copy() const = 0;
//! Update loading status. Checking for the license. //! Update loading status. Checking for the ability to read and write.
//! @param[in] theToImport flag to updates for import. Standard_True-import, Standard_False-export
//! @param[in] theToKeep flag to save update result
//! @return Standard_True, if node can be used //! @return Standard_True, if node can be used
Standard_EXPORT virtual bool UpdateLoad(); Standard_EXPORT virtual bool UpdateLoad(const Standard_Boolean theToImport,
const Standard_Boolean theToKeep);
public: public:

View File

@ -44,6 +44,7 @@ namespace
// purpose : // purpose :
//======================================================================= //=======================================================================
DE_Wrapper::DE_Wrapper() DE_Wrapper::DE_Wrapper()
:myKeepUpdates(Standard_False)
{} {}
//======================================================================= //=======================================================================
@ -67,6 +68,7 @@ DE_Wrapper::DE_Wrapper(const Handle(DE_Wrapper)& theWrapper)
Bind(aVendorIter.Value()); Bind(aVendorIter.Value());
} }
} }
theWrapper->myKeepUpdates = myKeepUpdates;
} }
//======================================================================= //=======================================================================
@ -445,7 +447,6 @@ void DE_Wrapper::ChangePriority(const TCollection_AsciiString& theFormat,
if (aVendorMap.FindFromKey(aVendorName, aNode)) if (aVendorMap.FindFromKey(aVendorName, aNode))
{ {
aNode->SetEnabled(Standard_True); aNode->SetEnabled(Standard_True);
aNode->UpdateLoad();
aNewVendorMap.Add(aVendorName, aNode); aNewVendorMap.Add(aVendorName, aNode);
} }
} }
@ -532,7 +533,8 @@ Standard_Boolean DE_Wrapper::FindProvider(const TCollection_AsciiString& thePath
((theToImport && aNode->IsImportSupported()) || ((theToImport && aNode->IsImportSupported()) ||
(!theToImport && aNode->IsExportSupported())) && (!theToImport && aNode->IsExportSupported())) &&
(aNode->CheckExtension(anExtr) || (aNode->CheckExtension(anExtr) ||
(theToImport && aNode->CheckContent(aBuffer)))) (theToImport && aNode->CheckContent(aBuffer))) &&
aNode->UpdateLoad(theToImport, myKeepUpdates))
{ {
theProvider = aNode->BuildProvider(); theProvider = aNode->BuildProvider();
aNode->GlobalParameters = GlobalParameters; aNode->GlobalParameters = GlobalParameters;
@ -544,6 +546,28 @@ Standard_Boolean DE_Wrapper::FindProvider(const TCollection_AsciiString& thePath
return Standard_False; return Standard_False;
} }
//=======================================================================
// function : UpdateLoad
// purpose :
//=======================================================================
Standard_EXPORT void DE_Wrapper::UpdateLoad(const Standard_Boolean theToForceUpdate) const
{
for (DE_ConfigurationFormatMap::Iterator aFormatIter(myConfiguration);
aFormatIter.More(); aFormatIter.Next())
{
for (DE_ConfigurationVendorMap::Iterator aVendorIter(aFormatIter.Value());
aVendorIter.More(); aVendorIter.Next())
{
const Handle(DE_ConfigurationNode)& aNode = aVendorIter.Value();
aNode->UpdateLoad(Standard_True, Standard_True);
aNode->UpdateLoad(Standard_False, Standard_True);
if (!theToForceUpdate)
continue;
aNode->SetEnabled(aNode->IsExportSupported() || aNode->IsImportSupported());
}
}
}
//======================================================================= //=======================================================================
// function : sort // function : sort
// purpose : // purpose :

View File

@ -226,6 +226,16 @@ public:
const Standard_Boolean theToImport, const Standard_Boolean theToImport,
Handle(DE_Provider)& theProvider) const; Handle(DE_Provider)& theProvider) const;
//! Updates all registered nodes, all changes will be saved in nodes
//! @param[in] theToForceUpdate flag that turns on/of nodes, according to updated ability to import/export
Standard_EXPORT void UpdateLoad(const Standard_Boolean theToForceUpdate = Standard_False) const;
//! Gets flag that keeps changes on configuration nodes which are being updated, false by default
Standard_Boolean KeepUpdates() const { return myKeepUpdates; }
//! Sets flag that keeps changes on configuration nodes which are being updated, false by default
void SetKeepUpdates(const Standard_Boolean theToKeepUpdates) { myKeepUpdates = theToKeepUpdates; }
//! Gets format map, contains vendor map with nodes //! Gets format map, contains vendor map with nodes
//! @return internal map of formats //! @return internal map of formats
Standard_EXPORT const DE_ConfigurationFormatMap& Nodes() const; Standard_EXPORT const DE_ConfigurationFormatMap& Nodes() const;
@ -248,6 +258,7 @@ public:
private: private:
Standard_Boolean myKeepUpdates; //!< Flag that keeps changes on configuration nodes which are being updated
DE_ConfigurationFormatMap myConfiguration; //!< Internal map of formats DE_ConfigurationFormatMap myConfiguration; //!< Internal map of formats
}; };

View File

@ -34,9 +34,7 @@ namespace
//======================================================================= //=======================================================================
DEBRepCascade_ConfigurationNode::DEBRepCascade_ConfigurationNode() : DEBRepCascade_ConfigurationNode::DEBRepCascade_ConfigurationNode() :
DE_ConfigurationNode() DE_ConfigurationNode()
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : DEBRepCascade_ConfigurationNode // function : DEBRepCascade_ConfigurationNode
@ -46,7 +44,6 @@ DEBRepCascade_ConfigurationNode::DEBRepCascade_ConfigurationNode(const Handle(DE
:DE_ConfigurationNode(theNode) :DE_ConfigurationNode(theNode)
{ {
InternalParameters = theNode->InternalParameters; InternalParameters = theNode->InternalParameters;
UpdateLoad();
} }
//======================================================================= //=======================================================================

View File

@ -34,9 +34,7 @@ namespace
//======================================================================= //=======================================================================
DEXCAFCascade_ConfigurationNode::DEXCAFCascade_ConfigurationNode() : DEXCAFCascade_ConfigurationNode::DEXCAFCascade_ConfigurationNode() :
DE_ConfigurationNode() DE_ConfigurationNode()
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : DEXCAFCascade_ConfigurationNode // function : DEXCAFCascade_ConfigurationNode
@ -46,7 +44,6 @@ DEXCAFCascade_ConfigurationNode::DEXCAFCascade_ConfigurationNode(const Handle(DE
:DE_ConfigurationNode(theNode) :DE_ConfigurationNode(theNode)
{ {
InternalParameters = theNode->InternalParameters; InternalParameters = theNode->InternalParameters;
UpdateLoad();
} }
//======================================================================= //=======================================================================

View File

@ -34,9 +34,7 @@ namespace
//======================================================================= //=======================================================================
IGESCAFControl_ConfigurationNode::IGESCAFControl_ConfigurationNode() : IGESCAFControl_ConfigurationNode::IGESCAFControl_ConfigurationNode() :
DE_ConfigurationNode() DE_ConfigurationNode()
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : IGESCAFControl_ConfigurationNode // function : IGESCAFControl_ConfigurationNode
@ -46,7 +44,6 @@ IGESCAFControl_ConfigurationNode::IGESCAFControl_ConfigurationNode(const Handle(
:DE_ConfigurationNode(theNode) :DE_ConfigurationNode(theNode)
{ {
InternalParameters = theNode->InternalParameters; InternalParameters = theNode->InternalParameters;
UpdateLoad();
} }
//======================================================================= //=======================================================================

View File

@ -33,9 +33,7 @@ namespace
//======================================================================= //=======================================================================
RWGltf_ConfigurationNode::RWGltf_ConfigurationNode() : RWGltf_ConfigurationNode::RWGltf_ConfigurationNode() :
DE_ConfigurationNode() DE_ConfigurationNode()
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : RWGltf_ConfigurationNode // function : RWGltf_ConfigurationNode
@ -45,7 +43,6 @@ RWGltf_ConfigurationNode::RWGltf_ConfigurationNode(const Handle(RWGltf_Configura
:DE_ConfigurationNode(theNode) :DE_ConfigurationNode(theNode)
{ {
InternalParameters = theNode->InternalParameters; InternalParameters = theNode->InternalParameters;
UpdateLoad();
} }
//======================================================================= //=======================================================================

View File

@ -33,9 +33,7 @@ namespace
//======================================================================= //=======================================================================
RWObj_ConfigurationNode::RWObj_ConfigurationNode() : RWObj_ConfigurationNode::RWObj_ConfigurationNode() :
DE_ConfigurationNode() DE_ConfigurationNode()
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : RWObj_ConfigurationNode // function : RWObj_ConfigurationNode
@ -45,7 +43,6 @@ RWObj_ConfigurationNode::RWObj_ConfigurationNode(const Handle(RWObj_Configuratio
:DE_ConfigurationNode(theNode) :DE_ConfigurationNode(theNode)
{ {
InternalParameters = theNode->InternalParameters; InternalParameters = theNode->InternalParameters;
UpdateLoad();
} }
//======================================================================= //=======================================================================

View File

@ -27,9 +27,7 @@ static const TCollection_AsciiString THE_CONFIGURATION_SCOPE = "provider";
//======================================================================= //=======================================================================
RWPly_ConfigurationNode::RWPly_ConfigurationNode() : RWPly_ConfigurationNode::RWPly_ConfigurationNode() :
DE_ConfigurationNode() DE_ConfigurationNode()
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : RWPly_ConfigurationNode // function : RWPly_ConfigurationNode
@ -39,7 +37,6 @@ RWPly_ConfigurationNode::RWPly_ConfigurationNode(const Handle(RWPly_Configuratio
:DE_ConfigurationNode(theNode) :DE_ConfigurationNode(theNode)
{ {
InternalParameters = theNode->InternalParameters; InternalParameters = theNode->InternalParameters;
UpdateLoad();
} }
//======================================================================= //=======================================================================

View File

@ -34,9 +34,7 @@ namespace
//======================================================================= //=======================================================================
RWStl_ConfigurationNode::RWStl_ConfigurationNode() : RWStl_ConfigurationNode::RWStl_ConfigurationNode() :
DE_ConfigurationNode() DE_ConfigurationNode()
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : STEPCAFControl_ConfigurationNode // function : STEPCAFControl_ConfigurationNode
@ -46,7 +44,6 @@ RWStl_ConfigurationNode::RWStl_ConfigurationNode(const Handle(RWStl_Configuratio
:DE_ConfigurationNode(theNode) :DE_ConfigurationNode(theNode)
{ {
InternalParameters = theNode->InternalParameters; InternalParameters = theNode->InternalParameters;
UpdateLoad();
} }
//======================================================================= //=======================================================================

View File

@ -34,9 +34,7 @@ namespace
//======================================================================= //=======================================================================
STEPCAFControl_ConfigurationNode::STEPCAFControl_ConfigurationNode() : STEPCAFControl_ConfigurationNode::STEPCAFControl_ConfigurationNode() :
DE_ConfigurationNode() DE_ConfigurationNode()
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : STEPCAFControl_ConfigurationNode // function : STEPCAFControl_ConfigurationNode
@ -45,9 +43,7 @@ STEPCAFControl_ConfigurationNode::STEPCAFControl_ConfigurationNode() :
STEPCAFControl_ConfigurationNode::STEPCAFControl_ConfigurationNode(const Handle(STEPCAFControl_ConfigurationNode)& theNode) STEPCAFControl_ConfigurationNode::STEPCAFControl_ConfigurationNode(const Handle(STEPCAFControl_ConfigurationNode)& theNode)
:DE_ConfigurationNode(theNode), :DE_ConfigurationNode(theNode),
InternalParameters(theNode->InternalParameters) InternalParameters(theNode->InternalParameters)
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : Load // function : Load

View File

@ -33,9 +33,7 @@ namespace
//======================================================================= //=======================================================================
Vrml_ConfigurationNode::Vrml_ConfigurationNode() : Vrml_ConfigurationNode::Vrml_ConfigurationNode() :
DE_ConfigurationNode() DE_ConfigurationNode()
{ {}
UpdateLoad();
}
//======================================================================= //=======================================================================
// function : STEPCAFControl_ConfigurationNode // function : STEPCAFControl_ConfigurationNode
@ -45,7 +43,6 @@ Vrml_ConfigurationNode::Vrml_ConfigurationNode(const Handle(Vrml_ConfigurationNo
:DE_ConfigurationNode(theNode) :DE_ConfigurationNode(theNode)
{ {
InternalParameters = theNode->InternalParameters; InternalParameters = theNode->InternalParameters;
UpdateLoad();
} }
//======================================================================= //=======================================================================