mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-08-14 13:30:48 +03:00
0026377: Passing Handle objects as arguments to functions as non-const reference to base type is dangerous
Operator of cast to non-const reference is declared deprecated to produce compiler warning if used (usually implicitly). OCCT code is updated to avoid that cast, occurring when function accepting non-const reference to handle is called with handle to derived type. For that, local variable of argument type is passed instead, and down-cast is used to get it to desired type after the call. A few occurrences of use of uninitialized variable are corrected.
This commit is contained in:
@@ -881,9 +881,9 @@ TNaming_Iterator::TNaming_Iterator(const TDF_Label& Lab,
|
||||
const Standard_Integer Trans)
|
||||
:myTrans(Trans)
|
||||
{
|
||||
Handle(TNaming_NamedShape) Att;
|
||||
Handle(TDF_Attribute) Att;
|
||||
if (Lab.FindAttribute(TNaming_NamedShape::GetID(),Trans,Att)) {
|
||||
myNode = Att->myNode;
|
||||
myNode = Handle(TNaming_NamedShape)::DownCast (Att)->myNode;
|
||||
}
|
||||
else {
|
||||
myNode = 0L;
|
||||
|
Reference in New Issue
Block a user