1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-06 18:26:22 +03:00
occt/src/BRepBuilderAPI/BRepBuilderAPI_MakeWire.hxx
cshorler ecac41a957 0026460: Implicit cast to TopoDS_Shape compilation error due to ambiguous conversion
- make operator TopoDS_Shape() cast a "non-const" member function
- make operator TopoDS_*() cast "non-const" when mutating behaviour is possible
- align derived class methods and overrides with the above changes

fix compilation for CR26460
- make argument for IsWRCase2 (non-const) BRepAlgoAPI_BooleanOperation&
2015-08-13 10:57:04 +03:00

208 lines
8.1 KiB
C++

// Created on: 1993-07-08
// Created by: Remi LEQUETTE
// Copyright (c) 1993-1999 Matra Datavision
// Copyright (c) 1999-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.
#ifndef _BRepBuilderAPI_MakeWire_HeaderFile
#define _BRepBuilderAPI_MakeWire_HeaderFile
#include <Standard.hxx>
#include <Standard_DefineAlloc.hxx>
#include <Standard_Handle.hxx>
#include <BRepLib_MakeWire.hxx>
#include <BRepBuilderAPI_MakeShape.hxx>
#include <TopTools_ListOfShape.hxx>
#include <Standard_Boolean.hxx>
#include <BRepBuilderAPI_WireError.hxx>
class StdFail_NotDone;
class TopoDS_Edge;
class TopoDS_Wire;
class TopoDS_Vertex;
//! Describes functions to build wires from edges. A wire can
//! be built from any number of edges.
//! To build a wire you first initialize the construction, then
//! add edges in sequence. An unlimited number of edges
//! can be added. The initialization of construction is done with:
//! - no edge (an empty wire), or
//! - edges of an existing wire, or
//! - up to four connectable edges.
//! In order to be added to a wire under construction, an
//! edge (unless it is the first one) must satisfy the following
//! condition: one of its vertices must be geometrically
//! coincident with one of the vertices of the wire (provided
//! that the highest tolerance factor is assigned to the two
//! vertices). It could also be the same vertex.
//! - The given edge is shared by the wire if it contains:
//! - two vertices, identical to two vertices of the wire
//! under construction (a general case of the wire closure), or
//! - one vertex, identical to a vertex of the wire under
//! construction; the other vertex not being
//! geometrically coincident with another vertex of the wire.
//! - In other cases, when one of the vertices of the edge
//! is simply geometrically coincident with a vertex of the
//! wire under construction (provided that the highest
//! tolerance factor is assigned to the two vertices), the
//! given edge is first copied and the coincident vertex is
//! replaced in this new edge, by the coincident vertex of the wire.
//! Note: it is possible to build non manifold wires using this construction tool.
//! A MakeWire object provides a framework for:
//! - initializing the construction of a wire,
//! - adding edges to the wire under construction, and
//! - consulting the result.
class BRepBuilderAPI_MakeWire : public BRepBuilderAPI_MakeShape
{
public:
DEFINE_STANDARD_ALLOC
//! Constructs an empty wire framework, to which edges
//! are added using the Add function.
//! As soon as the wire contains one edge, it can return
//! with the use of the function Wire.
//! Warning
//! The function Error will return
//! BRepBuilderAPI_EmptyWire if it is called before at
//! least one edge is added to the wire under construction.
Standard_EXPORT BRepBuilderAPI_MakeWire();
//! Make a Wire from an edge.
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Edge& E);
//! Make a Wire from two edges.
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Edge& E1, const TopoDS_Edge& E2);
//! Make a Wire from three edges.
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Edge& E1, const TopoDS_Edge& E2, const TopoDS_Edge& E3);
//! Make a Wire from four edges.
//! Constructs a wire
//! - from the TopoDS_Wire W composed of the edge E, or
//! - from edge E, or
//! - from two edges E1 and E2, or
//! - from three edges E1, E2 and E3, or
//! - from four edges E1, E2, E3 and E4.
//! Further edges can be added using the function Add.
//! Given edges are added in a sequence. Each of them
//! must be connectable to the wire under construction,
//! and so must satisfy the following condition (unless it is
//! the first edge of the wire): one of its vertices must be
//! geometrically coincident with one of the vertices of the
//! wire (provided that the highest tolerance factor is
//! assigned to the two vertices). It could also be the same vertex.
//! Warning
//! If an edge is not connectable to the wire under
//! construction it is not added. The function Error will
//! return BRepBuilderAPI_DisconnectedWire, the
//! function IsDone will return false and the function Wire
//! will raise an error, until a new connectable edge is added.
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Edge& E1, const TopoDS_Edge& E2, const TopoDS_Edge& E3, const TopoDS_Edge& E4);
//! Make a Wire from a Wire. Usefull for adding later.
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Wire& W);
//! Add an edge to a wire.
Standard_EXPORT BRepBuilderAPI_MakeWire(const TopoDS_Wire& W, const TopoDS_Edge& E);
//! Adds the edge E to the wire under construction.
//! E must be connectable to the wire under construction, and, unless it
//! is the first edge of the wire, must satisfy the following
//! condition: one of its vertices must be geometrically coincident
//! with one of the vertices of the wire (provided that the highest
//! tolerance factor is assigned to the two vertices). It could also
//! be the same vertex.
//! Warning
//! If E is not connectable to the wire under construction it is not
//! added. The function Error will return
//! BRepBuilderAPI_DisconnectedWire, the function IsDone will return
//! false and the function Wire will raise an error, until a new
//! connectable edge is added.
Standard_EXPORT void Add (const TopoDS_Edge& E);
//! Add the edges of <W> to the current wire.
Standard_EXPORT void Add (const TopoDS_Wire& W);
//! Adds the edges of <L> to the current wire. The
//! edges are not to be consecutive. But they are to
//! be all connected geometrically or topologically.
//! If some of them are not connected the Status give
//! DisconnectedWire but the "Maker" is Done() and you
//! can get the partial result. (ie connected to the
//! first edgeof the list <L>)
Standard_EXPORT void Add (const TopTools_ListOfShape& L);
//! Returns true if this algorithm contains a valid wire.
//! IsDone returns false if:
//! - there are no edges in the wire, or
//! - the last edge which you tried to add was not connectable.
Standard_EXPORT virtual Standard_Boolean IsDone() const Standard_OVERRIDE;
//! Returns the construction status
//! - BRepBuilderAPI_WireDone if the wire is built, or
//! - another value of the BRepBuilderAPI_WireError
//! enumeration indicating why the construction failed.
Standard_EXPORT BRepBuilderAPI_WireError Error() const;
//! Returns the constructed wire; or the part of the wire
//! under construction already built.
//! Exceptions StdFail_NotDone if a wire is not built.
Standard_EXPORT const TopoDS_Wire& Wire();
Standard_EXPORT operator TopoDS_Wire();
//! Returns the last edge added to the wire under construction.
//! Warning
//! - This edge can be different from the original one (the
//! argument of the function Add, for instance,)
//! - A null edge is returned if there are no edges in the
//! wire under construction, or if the last edge which you
//! tried to add was not connectable..
Standard_EXPORT const TopoDS_Edge& Edge() const;
//! Returns the last vertex of the last edge added to the
//! wire under construction.
//! Warning
//! A null vertex is returned if there are no edges in the wire
//! under construction, or if the last edge which you tried to
//! add was not connectableR
Standard_EXPORT const TopoDS_Vertex& Vertex() const;
protected:
private:
BRepLib_MakeWire myMakeWire;
};
#endif // _BRepBuilderAPI_MakeWire_HeaderFile