mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0024047: Exception in TPrsStd_AISPresentation during destruction of TDocStd_Document
Adding test case for this fix Modification in order to avoid exception during destruction of AIS_InteractiveContext Small modification for trihedron Small modifications to avoid regressions Cosmetic modification
This commit is contained in:
parent
efef9da8e5
commit
da0e82aac3
@ -199,6 +199,16 @@ void AIS_InteractiveContext::Delete() const
|
|||||||
// be performed when mgrSelector will be destroyed but anyway...
|
// be performed when mgrSelector will be destroyed but anyway...
|
||||||
mgrSelector->Remove( myMainSel );
|
mgrSelector->Remove( myMainSel );
|
||||||
#endif
|
#endif
|
||||||
|
AIS_ListOfInteractive aList;
|
||||||
|
|
||||||
|
AIS_DataMapIteratorOfDataMapOfIOStatus anIt(myObjects);
|
||||||
|
Handle(AIS_InteractiveContext) aNullContext;
|
||||||
|
for(; anIt.More() ; anIt.Next())
|
||||||
|
{
|
||||||
|
Handle(AIS_InteractiveObject) anObj = anIt.Key();
|
||||||
|
anObj->SetContext(aNullContext);
|
||||||
|
|
||||||
|
}
|
||||||
MMgt_TShared::Delete();
|
MMgt_TShared::Delete();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -155,6 +155,8 @@ Handle(AIS_InteractiveContext) AIS_InteractiveObject::GetContext() const
|
|||||||
void AIS_InteractiveObject::SetContext(const Handle(AIS_InteractiveContext)& aCtx)
|
void AIS_InteractiveObject::SetContext(const Handle(AIS_InteractiveContext)& aCtx)
|
||||||
{
|
{
|
||||||
myCTXPtr = aCtx.operator->();
|
myCTXPtr = aCtx.operator->();
|
||||||
|
if( aCtx.IsNull())
|
||||||
|
return;
|
||||||
if (myDrawer.IsNull()) {
|
if (myDrawer.IsNull()) {
|
||||||
myDrawer = new AIS_Drawer;
|
myDrawer = new AIS_Drawer;
|
||||||
#ifdef DEB
|
#ifdef DEB
|
||||||
|
@ -638,9 +638,20 @@ void AIS_Trihedron::LoadSubObjects()
|
|||||||
void AIS_Trihedron::SetContext(const Handle(AIS_InteractiveContext)& Ctx)
|
void AIS_Trihedron::SetContext(const Handle(AIS_InteractiveContext)& Ctx)
|
||||||
{
|
{
|
||||||
// Standard_Boolean same_DA = myDrawer->Link() == Ctx->DefaultDrawer();
|
// Standard_Boolean same_DA = myDrawer->Link() == Ctx->DefaultDrawer();
|
||||||
|
|
||||||
|
if( Ctx.IsNull())
|
||||||
|
{
|
||||||
|
Standard_Integer anIdx;
|
||||||
|
for (anIdx = 0; anIdx < 7; anIdx++)
|
||||||
|
{
|
||||||
|
myShapes[anIdx]->SetContext(Ctx);
|
||||||
|
}
|
||||||
|
AIS_InteractiveObject::SetContext (Ctx);
|
||||||
|
return;
|
||||||
|
}
|
||||||
// Remove subobjects from current context
|
// Remove subobjects from current context
|
||||||
Handle(AIS_InteractiveContext) anAISContext = GetContext();
|
Handle(AIS_InteractiveContext) anAISContext = GetContext();
|
||||||
|
|
||||||
Standard_Boolean hasContext = (anAISContext.IsNull() == Standard_False);
|
Standard_Boolean hasContext = (anAISContext.IsNull() == Standard_False);
|
||||||
Standard_Integer anIdx;
|
Standard_Integer anIdx;
|
||||||
for (anIdx = 0; anIdx < 7; anIdx++)
|
for (anIdx = 0; anIdx < 7; anIdx++)
|
||||||
@ -655,9 +666,8 @@ void AIS_Trihedron::SetContext(const Handle(AIS_InteractiveContext)& Ctx)
|
|||||||
}
|
}
|
||||||
myShapes[anIdx].Nullify();
|
myShapes[anIdx].Nullify();
|
||||||
}
|
}
|
||||||
|
|
||||||
AIS_InteractiveObject::SetContext (Ctx);
|
AIS_InteractiveObject::SetContext (Ctx);
|
||||||
|
|
||||||
LoadSubObjects();
|
LoadSubObjects();
|
||||||
for(Standard_Integer i= 0;i<=6;i++)
|
for(Standard_Integer i= 0;i<=6;i++)
|
||||||
myShapes[i]->SetContext (Ctx);
|
myShapes[i]->SetContext (Ctx);
|
||||||
|
@ -101,7 +101,9 @@ OpenGl_View::OpenGl_View (const CALL_DEF_VIEWCONTEXT &AContext)
|
|||||||
myIntShadingMethod(TEL_SM_GOURAUD),
|
myIntShadingMethod(TEL_SM_GOURAUD),
|
||||||
myAntiAliasing(Standard_False),
|
myAntiAliasing(Standard_False),
|
||||||
myTransPers(&myDefaultTransPers),
|
myTransPers(&myDefaultTransPers),
|
||||||
myIsTransPers(Standard_False)
|
myIsTransPers(Standard_False),
|
||||||
|
myTrihedron(NULL),
|
||||||
|
myGraduatedTrihedron(NULL)
|
||||||
{
|
{
|
||||||
// Initialize matrices
|
// Initialize matrices
|
||||||
memcpy(myOrientationMatrix,myDefaultMatrix,sizeof(Tmatrix3));
|
memcpy(myOrientationMatrix,myDefaultMatrix,sizeof(Tmatrix3));
|
||||||
@ -131,6 +133,7 @@ void OpenGl_View::ReleaseGlResources (const Handle(OpenGl_Context)& theCtx)
|
|||||||
{
|
{
|
||||||
OpenGl_Element::Destroy (theCtx, myTrihedron);
|
OpenGl_Element::Destroy (theCtx, myTrihedron);
|
||||||
OpenGl_Element::Destroy (theCtx, myGraduatedTrihedron);
|
OpenGl_Element::Destroy (theCtx, myGraduatedTrihedron);
|
||||||
|
|
||||||
if (!myTextureEnv.IsNull())
|
if (!myTextureEnv.IsNull())
|
||||||
{
|
{
|
||||||
theCtx->DelayedRelease (myTextureEnv);
|
theCtx->DelayedRelease (myTextureEnv);
|
||||||
@ -159,7 +162,8 @@ void OpenGl_View::SetTextureEnv (const Handle(OpenGl_Context)& theCtx,
|
|||||||
|
|
||||||
myTextureEnv = new OpenGl_Texture (theTexture->GetParams());
|
myTextureEnv = new OpenGl_Texture (theTexture->GetParams());
|
||||||
Handle(Image_PixMap) anImage = theTexture->GetImage();
|
Handle(Image_PixMap) anImage = theTexture->GetImage();
|
||||||
myTextureEnv->Init (theCtx, *anImage.operator->(), theTexture->Type());
|
if( !anImage.IsNull())
|
||||||
|
myTextureEnv->Init (theCtx, *anImage.operator->(), theTexture->Type());
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------------------------------------------------------*/
|
/*----------------------------------------------------------------------*/
|
||||||
|
@ -1032,10 +1032,11 @@ void TPrsStd_AISPresentation::AISErase (const Standard_Boolean remove)
|
|||||||
Handle(AIS_InteractiveContext) ctx, ownctx;
|
Handle(AIS_InteractiveContext) ctx, ownctx;
|
||||||
|
|
||||||
if ( !myAIS.IsNull() ) {
|
if ( !myAIS.IsNull() ) {
|
||||||
ownctx = myAIS->GetContext();
|
|
||||||
if ( !Label().IsNull()) {
|
if ( !Label().IsNull()) {
|
||||||
Handle(TPrsStd_AISViewer) viewer;
|
Handle(TPrsStd_AISViewer) viewer;
|
||||||
if( !TPrsStd_AISViewer::Find(Label(), viewer) ) return;
|
if( !TPrsStd_AISViewer::Find(Label(), viewer) ) return;
|
||||||
|
ownctx = myAIS->GetContext();
|
||||||
ctx = viewer->GetInteractiveContext();
|
ctx = viewer->GetInteractiveContext();
|
||||||
if( remove ) {
|
if( remove ) {
|
||||||
if( !ctx.IsNull() ) ctx->Remove (myAIS,Standard_False);
|
if( !ctx.IsNull() ) ctx->Remove (myAIS,Standard_False);
|
||||||
|
@ -98,6 +98,9 @@
|
|||||||
#include <AIS_Drawer.hxx>
|
#include <AIS_Drawer.hxx>
|
||||||
#include <Aspect_TypeOfLine.hxx>
|
#include <Aspect_TypeOfLine.hxx>
|
||||||
#include <Prs3d_LineAspect.hxx>
|
#include <Prs3d_LineAspect.hxx>
|
||||||
|
#include <TDocStd_Owner.hxx>
|
||||||
|
#include <Geom_Axis2Placement.hxx>
|
||||||
|
#include <AIS_Trihedron.hxx>
|
||||||
|
|
||||||
#define ZVIEW_SIZE 1000000.0
|
#define ZVIEW_SIZE 1000000.0
|
||||||
// avoid warnings on 'extern "C"' functions returning C++ classes
|
// avoid warnings on 'extern "C"' functions returning C++ classes
|
||||||
@ -1008,6 +1011,65 @@ static Standard_Integer XShowFaceBoundary (Draw_Interpretor& di,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=======================================================================
|
||||||
|
//function : testDoc
|
||||||
|
//purpose : Method to test destruction of document
|
||||||
|
//=======================================================================
|
||||||
|
static Standard_Integer testDoc (Draw_Interpretor& di,
|
||||||
|
Standard_Integer argc,
|
||||||
|
const char ** argv)
|
||||||
|
{
|
||||||
|
if( argc < 2 )
|
||||||
|
{
|
||||||
|
cout<<"Invalid numbers of arguments should be: XTestDoc shape"<<endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
TopoDS_Shape shape = DBRep::Get(argv[1]);
|
||||||
|
if( shape.IsNull())
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
Handle(XCAFApp_Application) A = XCAFApp_Application::GetApplication();
|
||||||
|
|
||||||
|
Handle(TDocStd_Document) aD1 = new TDocStd_Document("MDTV-XCAF");
|
||||||
|
aD1->Open(A);
|
||||||
|
|
||||||
|
Handle(V3d_Viewer) vw = ViewerTest_Tool::MakeViewer ("Test viwer");
|
||||||
|
Handle(AIS_InteractiveContext) aContext = new AIS_InteractiveContext(vw);
|
||||||
|
TPrsStd_AISViewer::New (aD1->Main(),aContext);
|
||||||
|
// get shape tool for shape verification
|
||||||
|
Handle(XCAFDoc_ShapeTool) aShapes =
|
||||||
|
XCAFDoc_DocumentTool::ShapeTool (aD1->Main());
|
||||||
|
TDF_Label aLab = aShapes->AddShape(shape);
|
||||||
|
|
||||||
|
Handle(Geom_Axis2Placement) aPlacement =
|
||||||
|
new Geom_Axis2Placement (gp::Origin(), gp::DZ(),gp::DX());
|
||||||
|
Handle(AIS_Trihedron) aTriShape = new AIS_Trihedron (aPlacement);
|
||||||
|
|
||||||
|
Handle(TNaming_NamedShape) NS;
|
||||||
|
Handle(TPrsStd_AISPresentation) prs;
|
||||||
|
if( aLab.FindAttribute( TNaming_NamedShape::GetID(), NS) ) {
|
||||||
|
prs = TPrsStd_AISPresentation::Set( NS );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( aLab.FindAttribute(TPrsStd_AISPresentation::GetID(), prs) )
|
||||||
|
prs->Display();
|
||||||
|
|
||||||
|
|
||||||
|
TPrsStd_AISViewer::Update(aLab);
|
||||||
|
aContext->Display(aTriShape, Standard_True);
|
||||||
|
Handle(TDocStd_Owner) owner;
|
||||||
|
if (aD1->Main().Root().FindAttribute(TDocStd_Owner::GetID(), owner))
|
||||||
|
{
|
||||||
|
Handle_TDocStd_Document empty;
|
||||||
|
owner->SetDocument(empty);
|
||||||
|
}
|
||||||
|
aContext.Nullify();
|
||||||
|
aD1->Close();
|
||||||
|
aD1.Nullify();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : Init
|
//function : Init
|
||||||
//purpose :
|
//purpose :
|
||||||
@ -1082,6 +1144,7 @@ void XDEDRAW::Init(Draw_Interpretor& di)
|
|||||||
"Doc Label IsOn [R G B [LineWidth [LineStyle]]]:"
|
"Doc Label IsOn [R G B [LineWidth [LineStyle]]]:"
|
||||||
"- turns on/off drawing of face boundaries and defines boundary line style",
|
"- turns on/off drawing of face boundaries and defines boundary line style",
|
||||||
__FILE__, XShowFaceBoundary, g);
|
__FILE__, XShowFaceBoundary, g);
|
||||||
|
di.Add ("XTestDoc", "XTestDoc shape", __FILE__, testDoc, g);
|
||||||
|
|
||||||
// Specialized commands
|
// Specialized commands
|
||||||
XDEDRAW_Shapes::InitCommands ( di );
|
XDEDRAW_Shapes::InitCommands ( di );
|
||||||
|
12
tests/bugs/caf/bug24047
Executable file
12
tests/bugs/caf/bug24047
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
puts "============"
|
||||||
|
puts "OCC24047"
|
||||||
|
puts "============"
|
||||||
|
puts ""
|
||||||
|
#######################################################################
|
||||||
|
# Exception in TPrsStd_AISPresentation during destruction of TDocStd_Document
|
||||||
|
#######################################################################
|
||||||
|
|
||||||
|
pload XDEDRAW
|
||||||
|
|
||||||
|
box a 0 0 0 10 10 10
|
||||||
|
XTestDoc a
|
Loading…
x
Reference in New Issue
Block a user