From 6766feb5edadcdb5eabf7e8cbba7e343791b618d Mon Sep 17 00:00:00 2001 From: dpasukhi Date: Sat, 4 Jan 2025 12:38:42 +0000 Subject: [PATCH] Foundation Classes - Optimize IsKind operation #234 Refactor Standard_Type::SubType methods for improved clarity and performance --- src/Standard/Standard_Type.cxx | 46 +++++++++++++++++++++++----------- 1 file changed, 32 insertions(+), 14 deletions(-) diff --git a/src/Standard/Standard_Type.cxx b/src/Standard/Standard_Type.cxx index 6321deab29..875e7c3e5b 100644 --- a/src/Standard/Standard_Type.cxx +++ b/src/Standard/Standard_Type.cxx @@ -31,26 +31,44 @@ Standard_Type::Standard_Type (const std::type_info& theInfo, myName(theName), mySize(theSize), myParent(theParent) +{} + +Standard_Boolean Standard_Type::SubType(const Handle(Standard_Type)& theOther) const { + if (theOther.IsNull()) + { + return false; + } + const Standard_Type* aTypeIter = this; + while (aTypeIter && theOther->mySize <= aTypeIter->mySize) + { + if (theOther.get() == aTypeIter) + { + return true; + } + aTypeIter = aTypeIter->Parent().get(); + } + return false; } -//============================================================================ - -Standard_Boolean Standard_Type::SubType (const Handle(Standard_Type)& theOther) const +Standard_Boolean Standard_Type::SubType(const Standard_CString theName) const { - return ! theOther.IsNull() && (theOther == this || (! myParent.IsNull() && myParent->SubType (theOther))); + if (!theName) + { + return false; + } + const Standard_Type* aTypeIter = this; + while (aTypeIter) + { + if (IsEqual(theName, aTypeIter->Name())) + { + return true; + } + aTypeIter = aTypeIter->Parent().get(); + } + return false; } -//============================================================================ - -Standard_Boolean Standard_Type::SubType (const Standard_CString theName) const -{ - return theName != 0 && (IsEqual (myName, theName) || (! myParent.IsNull() && myParent->SubType (theName))); -} - -// ------------------------------------------------------------------ -// Print (me; s: in out OStream) returns OStream; -// ------------------------------------------------------------------ void Standard_Type::Print (Standard_OStream& AStream) const { AStream << std::hex << (Standard_Address)this << " : " << std::dec << myName ;