mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-10 18:51:21 +03:00
Macro NO_CXX_EXCEPTION was removed from code. Method Raise() was replaced by explicit throw statement. Method Standard_Failure::Caught() was replaced by normal C++mechanism of exception transfer. Method Standard_Failure::Caught() is deprecated now. Eliminated empty constructors. Updated samples. Eliminate empty method ChangeValue from NCollection_Map class. Removed not operable methods from NCollection classes.
290 lines
9.7 KiB
C++
290 lines
9.7 KiB
C++
// Created on: 2007-11-25
|
|
// Created by: Alexander GRIGORIEV
|
|
// Copyright (c) 2007-2014 OPEN CASCADE SAS
|
|
//
|
|
// This file is part of Open CASCADE Technology software library.
|
|
//
|
|
// This library is free software; you can redistribute it and/or modify it under
|
|
// the terms of the GNU Lesser General Public License version 2.1 as published
|
|
// by the Free Software Foundation, with special exception defined in the file
|
|
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
// distribution for complete text of the license and disclaimer of any warranty.
|
|
//
|
|
// Alternatively, this file may be used under the terms of Open CASCADE
|
|
// commercial license or contractual agreement.
|
|
|
|
#include <Poly_CoherentTriangle.hxx>
|
|
#include <Standard_ProgramError.hxx>
|
|
|
|
//=======================================================================
|
|
//function : Poly_CoherentTriangle()
|
|
//purpose : Empty Constructor
|
|
//=======================================================================
|
|
|
|
Poly_CoherentTriangle::Poly_CoherentTriangle ()
|
|
: myNConnections (0)
|
|
{
|
|
myNodes[0] = -1;
|
|
myNodes[1] = -1;
|
|
myNodes[2] = -1;
|
|
myNodesOnConnected[0] = -1;
|
|
myNodesOnConnected[1] = -1;
|
|
myNodesOnConnected[2] = -1;
|
|
mypConnected[0] = 0L;
|
|
mypConnected[1] = 0L;
|
|
mypConnected[2] = 0L;
|
|
mypLink[0] = 0L;
|
|
mypLink[1] = 0L;
|
|
mypLink[2] = 0L;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Poly_CoherentTriangle()
|
|
//purpose : Constructor
|
|
//=======================================================================
|
|
|
|
Poly_CoherentTriangle::Poly_CoherentTriangle (const Standard_Integer iNode0,
|
|
const Standard_Integer iNode1,
|
|
const Standard_Integer iNode2)
|
|
: myNConnections (0)
|
|
{
|
|
myNodes[0] = iNode0;
|
|
myNodes[1] = iNode1;
|
|
myNodes[2] = iNode2;
|
|
myNodesOnConnected[0] = -1;
|
|
myNodesOnConnected[1] = -1;
|
|
myNodesOnConnected[2] = -1;
|
|
mypConnected[0] = 0L;
|
|
mypConnected[1] = 0L;
|
|
mypConnected[2] = 0L;
|
|
mypLink[0] = 0L;
|
|
mypLink[1] = 0L;
|
|
mypLink[2] = 0L;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetConnection
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean Poly_CoherentTriangle::SetConnection
|
|
(const Standard_Integer iConn,
|
|
Poly_CoherentTriangle& theTr)
|
|
{
|
|
Standard_Boolean aResult(Standard_False);
|
|
static const Standard_Integer II[] = { 2, 0, 1, 2, 0 };
|
|
|
|
if (theTr.Node(0) == myNodes[II[iConn+2]]) {
|
|
if (theTr.Node(2) == myNodes[II[iConn]]) {
|
|
RemoveConnection(iConn);
|
|
myNodesOnConnected[iConn] = theTr.Node(1);
|
|
mypConnected[iConn] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(1);
|
|
theTr.myNodesOnConnected[1] = myNodes[iConn];
|
|
theTr.mypConnected[1] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
}
|
|
} else if (theTr.Node(1) == myNodes[II[iConn+2]]) {
|
|
if (theTr.Node(0) == myNodes[II[iConn]]) {
|
|
RemoveConnection(iConn);
|
|
myNodesOnConnected[iConn] = theTr.Node(2);
|
|
mypConnected[iConn] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(2);
|
|
theTr.myNodesOnConnected[2] = myNodes[iConn];
|
|
theTr.mypConnected[2] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
}
|
|
} else if (theTr.Node(2) == myNodes[II[iConn+2]]) {
|
|
if (theTr.Node(1) == myNodes[II[iConn]]) {
|
|
RemoveConnection(iConn);
|
|
myNodesOnConnected[iConn] = theTr.Node(0);
|
|
mypConnected[iConn] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(0);
|
|
theTr.myNodesOnConnected[0] = myNodes[iConn];
|
|
theTr.mypConnected[0] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
}
|
|
}
|
|
return aResult;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetConnection
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean Poly_CoherentTriangle::SetConnection
|
|
(Poly_CoherentTriangle& theTr)
|
|
{
|
|
Standard_Boolean aResult(Standard_False);
|
|
if (myNodes[0] == theTr.Node(0)) {
|
|
if (myNodes[1] == theTr.Node(2) && mypConnected[2] != &theTr) {
|
|
RemoveConnection(2);
|
|
myNodesOnConnected[2] = theTr.Node(1);
|
|
mypConnected[2] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(1);
|
|
theTr.myNodesOnConnected[1] = myNodes[2];
|
|
theTr.mypConnected[1] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
} else if (myNodes[2] == theTr.Node(1) && mypConnected[1] != &theTr) {
|
|
RemoveConnection(1);
|
|
myNodesOnConnected[1] = theTr.Node(2);
|
|
mypConnected[1] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(2);
|
|
theTr.myNodesOnConnected[2] = myNodes[1];
|
|
theTr.mypConnected[2] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
}
|
|
} else if (myNodes[0] == theTr.Node(1)) {
|
|
if (myNodes[1] == theTr.Node(0) && mypConnected[2] != &theTr) {
|
|
RemoveConnection(2);
|
|
myNodesOnConnected[2] = theTr.Node(2);
|
|
mypConnected[2] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(2);
|
|
theTr.myNodesOnConnected[2] = myNodes[2];
|
|
theTr.mypConnected[2] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
} else if (myNodes[2] == theTr.Node(2) && mypConnected[1] != &theTr) {
|
|
RemoveConnection(1);
|
|
myNodesOnConnected[1] = theTr.Node(0);
|
|
mypConnected[1] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(0);
|
|
theTr.myNodesOnConnected[0] = myNodes[1];
|
|
theTr.mypConnected[0] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
}
|
|
} else if (myNodes[0] == theTr.Node(2)) {
|
|
if (myNodes[1] == theTr.Node(1) && mypConnected[2] != &theTr) {
|
|
RemoveConnection(2);
|
|
myNodesOnConnected[2] = theTr.Node(0);
|
|
mypConnected[2] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(0);
|
|
theTr.myNodesOnConnected[0] = myNodes[2];
|
|
theTr.mypConnected[0] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
} else if (myNodes[2] == theTr.Node(0) && mypConnected[1] != &theTr) {
|
|
RemoveConnection(1);
|
|
myNodesOnConnected[1] = theTr.Node(1);
|
|
mypConnected[1] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(1);
|
|
theTr.myNodesOnConnected[1] = myNodes[1];
|
|
theTr.mypConnected[1] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
}
|
|
} else if (mypConnected[0] != &theTr) {
|
|
if (myNodes[1] == theTr.Node(0) && myNodes[2] == theTr.Node(2)) {
|
|
RemoveConnection(0);
|
|
myNodesOnConnected[0] = theTr.Node(1);
|
|
mypConnected[0] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(1);
|
|
theTr.myNodesOnConnected[1] = myNodes[0];
|
|
theTr.mypConnected[1] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
} else if (myNodes[1] == theTr.Node(2) && myNodes[2] == theTr.Node(1)) {
|
|
RemoveConnection(0);
|
|
myNodesOnConnected[0] = theTr.Node(0);
|
|
mypConnected[0] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(0);
|
|
theTr.myNodesOnConnected[0] = myNodes[0];
|
|
theTr.mypConnected[0] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
} else if (myNodes[1] == theTr.Node(1) && myNodes[2] == theTr.Node(0)) {
|
|
RemoveConnection(0);
|
|
myNodesOnConnected[0] = theTr.Node(2);
|
|
mypConnected[0] = &theTr;
|
|
myNConnections++;
|
|
theTr.RemoveConnection(2);
|
|
theTr.myNodesOnConnected[2] = myNodes[0];
|
|
theTr.mypConnected[2] = this;
|
|
theTr.myNConnections++;
|
|
aResult = Standard_True;
|
|
}
|
|
}
|
|
return aResult;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : RemoveConnection
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void Poly_CoherentTriangle::RemoveConnection(const Standard_Integer iConn)
|
|
{
|
|
Poly_CoherentTriangle * pConnectedTri =
|
|
const_cast<Poly_CoherentTriangle *> (mypConnected[iConn]);
|
|
if (pConnectedTri) {
|
|
Standard_Integer iConn1(0);
|
|
if (pConnectedTri->mypConnected[0] != this) {
|
|
if (pConnectedTri->mypConnected[1] == this)
|
|
iConn1 = 1;
|
|
else if (pConnectedTri->mypConnected[2] == this)
|
|
iConn1 = 2;
|
|
else
|
|
throw Standard_ProgramError("Poly_CoherentTriangle::RemoveConnection: "
|
|
"wrong connection between triangles");
|
|
}
|
|
pConnectedTri->mypConnected[iConn1] = 0L;
|
|
pConnectedTri->myNodesOnConnected[iConn1] = -1;
|
|
pConnectedTri->myNConnections--;
|
|
mypConnected[iConn] = 0L;
|
|
myNodesOnConnected[iConn] = -1;
|
|
myNConnections--;
|
|
}
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : RemoveConnection
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean Poly_CoherentTriangle::RemoveConnection
|
|
(Poly_CoherentTriangle& theTri)
|
|
{
|
|
const Standard_Integer iConn = FindConnection(theTri);
|
|
if (iConn >= 0)
|
|
RemoveConnection(iConn);
|
|
return (iConn >= 0);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : FindConnection
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Integer Poly_CoherentTriangle::FindConnection
|
|
(const Poly_CoherentTriangle& theTri) const
|
|
{
|
|
Standard_Integer aResult;
|
|
if (mypConnected[0] == &theTri)
|
|
aResult = 0;
|
|
else if (mypConnected[1] == &theTri)
|
|
aResult = 1;
|
|
else if (mypConnected[2] == &theTri)
|
|
aResult = 2;
|
|
else
|
|
aResult = -1;
|
|
return aResult;
|
|
}
|