mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0023523: In session DRAW it is impossible to close document having name already once closed document.
Added destructor for TDocStd_Document which performs destruction of document in logical order in order to avoid exception when Undo and Redo fields are destructed after THF_Data field. Added removing name of closed document from tcl variables in the DRAW in order to avoid exception during use the same name for new document. Modification to avoid compilation error class ViewerTest Minor correction in test caf basic G3
This commit is contained in:
parent
7a06c690fb
commit
24de79c3a5
@ -68,9 +68,10 @@ is
|
||||
|
||||
Initialize;
|
||||
|
||||
Destroy(me: mutable) is protected;
|
||||
---C++: alias ~
|
||||
---Category: virtual methods
|
||||
Destroy(me: mutable) is virtual protected;
|
||||
---C++: alias ~
|
||||
|
||||
|
||||
Update(me: mutable; aToDocument: Document from CDM; aReferenceIdentifier: Integer from Standard; aModifContext: Address from Standard)
|
||||
---Purpose: The Update method will be called once for each
|
||||
|
@ -297,8 +297,11 @@ static Standard_Integer DDocStd_Close (Draw_Interpretor& di,
|
||||
Handle(TDocStd_Application) A;
|
||||
if (!DDocStd::Find(A)) return 1;
|
||||
A->Close(D);
|
||||
|
||||
Handle(Draw_Drawable3D) DD = Draw::Get(a[1],Standard_False);
|
||||
dout.RemoveDrawable (DD);
|
||||
Handle(Draw_Drawable3D) aDNull;
|
||||
Draw::Set(a[1], aDNull);
|
||||
return 0;
|
||||
}
|
||||
di << "DDocStd_Close : Error" << "\n";
|
||||
|
@ -49,9 +49,9 @@ uses Data from TDF,
|
||||
|
||||
is
|
||||
|
||||
--Destroy (me : mutable);
|
||||
---Purpose: Will Abort any execution, and commit the Undo transaction
|
||||
-----C++: alias ~
|
||||
Destroy (me : mutable) is redefined protected;
|
||||
---Purpose: Will Abort any execution, clear fields
|
||||
---C++: alias ~
|
||||
|
||||
Get (myclass; L : Label from TDF)
|
||||
---Purpose: returns the document which contains <L>. raises an
|
||||
|
@ -74,10 +74,17 @@ Handle(TDocStd_Document) TDocStd_Document::Get (const TDF_Label& acces)
|
||||
//function : Destroy
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
// void TDocStd_Document::Destroy()
|
||||
// {
|
||||
// myUndoTransaction.Commit(); // no needs to store the Undo
|
||||
// }
|
||||
void TDocStd_Document::Destroy()
|
||||
{
|
||||
SetModificationMode(Standard_False);
|
||||
myData->Root().ForgetAllAttributes(Standard_True);
|
||||
myUndoTransaction.Abort();
|
||||
if(!myUndoFILO.IsEmpty())
|
||||
myUndoFILO.Clear();
|
||||
ClearUndos();
|
||||
myData.Nullify();
|
||||
|
||||
}
|
||||
|
||||
|
||||
//=======================================================================
|
||||
|
@ -135,7 +135,7 @@ is
|
||||
GetCollectorFromContext returns Viewer from V3d;
|
||||
|
||||
GetAISContext returns InteractiveContext from AIS;
|
||||
|
||||
---C++: return const &
|
||||
GetNISContext returns InteractiveContext from NIS;
|
||||
---C++: return &
|
||||
|
||||
@ -144,7 +144,8 @@ is
|
||||
SetNISContext (aContext: InteractiveContext from NIS);
|
||||
|
||||
CurrentView returns View from V3d;
|
||||
|
||||
---C++: return const &
|
||||
|
||||
CurrentView (aViou:View from V3d);
|
||||
|
||||
Clear ;
|
||||
|
@ -334,17 +334,19 @@ static void VwrTst_InitEventMgr(const Handle(NIS_View)& aView,
|
||||
theEventMgrs.Prepend(new ViewerTest_EventManager(aView, Ctx));
|
||||
}
|
||||
|
||||
static Handle(V3d_View)& a3DView(){
|
||||
static Handle(V3d_View)& a3DView()
|
||||
{
|
||||
static Handle(V3d_View) Viou;
|
||||
return Viou;
|
||||
}
|
||||
|
||||
|
||||
Standard_EXPORT Handle(AIS_InteractiveContext)& TheAISContext(){
|
||||
static Handle(AIS_InteractiveContext) aContext;
|
||||
return aContext;
|
||||
}
|
||||
|
||||
Handle(V3d_View) ViewerTest::CurrentView()
|
||||
const Handle(V3d_View)& ViewerTest::CurrentView()
|
||||
{
|
||||
return a3DView();
|
||||
}
|
||||
@ -363,7 +365,7 @@ Standard_EXPORT const Handle(NIS_InteractiveContext)& TheNISContext()
|
||||
return aContext;
|
||||
}
|
||||
|
||||
Handle(AIS_InteractiveContext) ViewerTest::GetAISContext()
|
||||
const Handle(AIS_InteractiveContext)& ViewerTest::GetAISContext()
|
||||
{
|
||||
return TheAISContext();
|
||||
}
|
||||
|
@ -21,7 +21,7 @@ for {set i 1} {$i < 10} {incr i} {
|
||||
|
||||
# close document
|
||||
Close D
|
||||
unset D
|
||||
|
||||
|
||||
# unload shape (replace by small one)
|
||||
vertex a 0 0 0
|
||||
|
@ -39,7 +39,7 @@ set aFile ${imagedir}/caf001-G3.std
|
||||
file delete ${aFile}
|
||||
SaveAs D ${aFile}
|
||||
if { ![file exists ${aFile}] } {
|
||||
puts "There is not ${aFile} file; SaveAs command: Error"
|
||||
puts "There is no file ${aFile}; SaveAs command: Error"
|
||||
return
|
||||
}
|
||||
#catch {exec chmod 777 ${aFile}}
|
||||
|
@ -64,6 +64,7 @@ if { ${IsDone} != 0 } {
|
||||
puts "Get a value of TPrsStd_AISPresentation attribute from restoring document: Error"
|
||||
puts "OCC1228: ERROR (case 2)"
|
||||
} else {
|
||||
Close DDoc
|
||||
puts "There is the box in the viewer"
|
||||
puts "OCC1228: OK"
|
||||
}
|
||||
|
@ -18,7 +18,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
isos 12
|
||||
#1 - create box using more flexible set of commands
|
||||
|
@ -18,7 +18,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
|
||||
#Drivers' nick-names:
|
||||
|
@ -17,7 +17,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
|
||||
AddDriver D Box Cyl Sph Attach XAttach PTxyz PTALine PRLine PMirr Cut Fuse Prism FulRevol SecRevol Fillet
|
||||
|
@ -17,7 +17,7 @@
|
||||
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
|
||||
AddDriver D Box Cyl Sph Attach XAttach PTxyz PTALine PRLine PMirr Cut Fuse Prism FulRevol SecRevol Fillet
|
||||
|
@ -17,7 +17,7 @@
|
||||
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
|
||||
AddDriver D Box Cyl Sph Attach XAttach PTxyz PTALine PRLine PMirr Cut Fuse Prism FulRevol SecRevol Fillet
|
||||
|
@ -21,7 +21,7 @@
|
||||
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
|
||||
#1 - create Box using short-cut
|
||||
|
@ -21,7 +21,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
|
||||
#Drivers' nick-names:
|
||||
|
@ -19,7 +19,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
|
||||
#Drivers' nick-names:
|
||||
|
@ -18,7 +18,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
isos 12
|
||||
|
||||
|
@ -22,7 +22,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
AddDriver D Box Cyl Sph Attach XAttach PTxyz PTALine PRLine PMirr Cut Fuse Prism FulRevol SecRevol Fillet
|
||||
|
||||
|
@ -19,7 +19,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
isos 12
|
||||
#1 - create Box using short-cut
|
||||
|
@ -25,7 +25,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
isos 12
|
||||
#1 - create Box using short-cut
|
||||
|
@ -17,7 +17,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
|
||||
#Drivers' nick-names:
|
||||
|
@ -20,7 +20,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
isos 12
|
||||
|
||||
|
@ -22,7 +22,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
isos 12
|
||||
|
||||
|
@ -21,7 +21,7 @@
|
||||
#pload FULL
|
||||
erase
|
||||
Close D
|
||||
unset D
|
||||
|
||||
NewDocument D MDTV-Standard
|
||||
isos 12
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user