mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
0030835: Possible performance improvements in methods TDF_Label::FindAttribute
Make attribute iterator work with pointers to attributes, so, creation of handle on each iteration is avoided.
This commit is contained in:
parent
607e5e62e7
commit
c2100640f6
@ -61,6 +61,9 @@ public:
|
||||
Standard_EXPORT void Next() ;
|
||||
inline Handle(TDF_Attribute) Value() const;
|
||||
|
||||
//! Provides an access to the internal pointer of the current attribute.
|
||||
//! The method has better performance as not-creating handle.
|
||||
inline const TDF_Attribute* PtrValue() const { return myValue; }
|
||||
|
||||
protected:
|
||||
|
||||
|
@ -60,8 +60,8 @@ Standard_Boolean TDF_Label::FindAttribute
|
||||
if (IsNull()) throw Standard_NullObject("A null Label has no attribute.");
|
||||
TDF_AttributeIterator itr (myLabelNode); // Without removed attributes.
|
||||
for ( ; itr.More(); itr.Next()) {
|
||||
if (itr.Value()->ID() == anID) {
|
||||
anAttribute = itr.Value();
|
||||
if (itr.PtrValue()->ID() == anID) {
|
||||
anAttribute = itr.PtrValue();
|
||||
return Standard_True;
|
||||
}
|
||||
}
|
||||
|
@ -154,7 +154,7 @@ public:
|
||||
template <class T>
|
||||
Standard_Boolean FindAttribute (const Standard_GUID& theID, Handle(T)& theAttr) const
|
||||
{
|
||||
Handle(TDF_Attribute) anAttr = theAttr;
|
||||
Handle(TDF_Attribute) anAttr;
|
||||
return FindAttribute (theID, anAttr) && ! (theAttr = Handle(T)::DownCast(anAttr)).IsNull();
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user