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:
@@ -280,10 +280,14 @@ static Standard_Boolean IsCurrent (const Standard_CString name)
|
||||
|
||||
Handle(TCollection_HAsciiString) sw, val;
|
||||
if (!thecurconf->GetItem (name,sw,Standard_True)) sw.Nullify();
|
||||
Handle(Standard_Transient) aVal;
|
||||
if (!sw.IsNull()) {
|
||||
if (!opt->Item (sw->ToCString(),val)) val.Nullify();
|
||||
if (!opt->Item (sw->ToCString(),aVal))
|
||||
aVal.Nullify();
|
||||
}
|
||||
if (val.IsNull() && !proper) opt->Value(val);
|
||||
if (aVal.IsNull() && !proper)
|
||||
opt->Value(aVal);
|
||||
val = Handle(TCollection_HAsciiString)::DownCast (aVal);
|
||||
|
||||
// On applique
|
||||
if (!val.IsNull()) tv->SetHStringValue (val);
|
||||
|
Reference in New Issue
Block a user