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:
parent
74cb5673a5
commit
669e0dfc17
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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:
|
||||||
|
|
||||||
|
@ -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 :
|
||||||
|
@ -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
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
|
Loading…
x
Reference in New Issue
Block a user