1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-07-30 13:05:50 +03:00
occt/src/IGESDraw/IGESDraw_RectArraySubfigure.cxx
kgv dde6883382 0027772: Foundation Classes - define Standard_Boolean using C++ type "bool" instead of "unsigned int"
Code has been updated to remove no-op casts and implicit casts to Standard_Boolean.

Places of inproper use of Standard_Boolean instead of Standard_Integer
have been corrected:
- Bnd_Box, Bnd_Box2d
  Bit flags are now defined as private enum
- HLRAlgo_BiPoint, HLRAlgo_EdgesBlock, HLRBRep_EdgeData, HLRBRep_FaceData
  Bit flags are now defined as enum
- HLRAlgo_EdgeStatus, HLRBRep_BiPnt2D, HLRBRep_BiPoint
  Bit flags are now defined as bool fields
- HLRAlgo_PolyData
  Bit flags are now defined as Standard_Integer
- OSD_DirectoryIterator, OSD_FileIterator
  Boolean flag is now defined as Standard_Boolean
- ShapeAnalysis_Surface::SurfaceNewton()
  now returns Standard_Integer (values 0, 1 or 3)
- ChFi2d_FilletAlgo
  now uses TColStd_SequenceOfBoolean instead of TColStd_SequenceOfInteger
  for storing boolean flags

Method IFSelect_Dispatch::PacketsCount() has been dropped from interface.

ShapeFix_Solid::Status() has been fixed to decode requested status
instead of returning integer value.

TopOpeBRepBuild_Builder1 now defines map storing Standard_Boolean values
instead of Standard_Integer.

Persistence for Standard_Boolean type has been corrected
to keep backward compatibility:
- BinMDataStd, BinTools, FSD_BinaryFile

Broken Draw Harness commands vdisplaymode and verasemode have been removed.

BRepMesh_FastDiscretFace::initDataStructure() - workaround old gcc limitations

BRepMesh_IncrementalMesh::clear() - avoid ambiguity
2016-08-26 10:16:17 +03:00

151 lines
4.6 KiB
C++

// Created by: CKY / Contract Toubro-Larsen
// 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.
//--------------------------------------------------------------------
//--------------------------------------------------------------------
#include <gp_GTrsf.hxx>
#include <gp_Pnt.hxx>
#include <gp_XYZ.hxx>
#include <IGESData_IGESEntity.hxx>
#include <IGESDraw_RectArraySubfigure.hxx>
#include <Standard_DimensionMismatch.hxx>
#include <Standard_OutOfRange.hxx>
#include <Standard_Type.hxx>
IMPLEMENT_STANDARD_RTTIEXT(IGESDraw_RectArraySubfigure,IGESData_IGESEntity)
IGESDraw_RectArraySubfigure::IGESDraw_RectArraySubfigure () { }
void IGESDraw_RectArraySubfigure::Init
(const Handle(IGESData_IGESEntity)& aBase,
const Standard_Real aScale,
const gp_XYZ& aCorner,
const Standard_Integer nbCols,
const Standard_Integer nbRows,
const Standard_Real hDisp,
const Standard_Real vtDisp,
const Standard_Real rotationAngle,
const Standard_Integer doDont,
const Handle(TColStd_HArray1OfInteger)& allNumPos)
{
if (!allNumPos.IsNull())
if (allNumPos->Lower() != 1)
Standard_DimensionMismatch::Raise("IGESDraw_RectArraySubfigure : Init");
theBaseEntity = aBase;
theScaleFactor = aScale;
theLowerLeftCorner = aCorner;
theNbColumns = nbCols;
theNbRows = nbRows;
theColumnSeparation = hDisp;
theRowSeparation = vtDisp;
theRotationAngle = rotationAngle;
theDoDontFlag = doDont != 0;
thePositions = allNumPos;
InitTypeAndForm(412,0);
}
Handle(IGESData_IGESEntity) IGESDraw_RectArraySubfigure::BaseEntity () const
{
return theBaseEntity;
}
Standard_Real IGESDraw_RectArraySubfigure::ScaleFactor () const
{
return theScaleFactor;
}
gp_Pnt IGESDraw_RectArraySubfigure::LowerLeftCorner () const
{
gp_Pnt tempLowerLeftCorner(theLowerLeftCorner);
return tempLowerLeftCorner;
}
gp_Pnt IGESDraw_RectArraySubfigure::TransformedLowerLeftCorner () const
{
gp_XYZ tempLowerLeftCorner = theLowerLeftCorner;
if (HasTransf()) Location().Transforms(tempLowerLeftCorner);
gp_Pnt tempRes(tempLowerLeftCorner);
return (tempRes);
}
Standard_Integer IGESDraw_RectArraySubfigure::NbColumns () const
{
return theNbColumns;
}
Standard_Integer IGESDraw_RectArraySubfigure::NbRows () const
{
return theNbRows;
}
Standard_Real IGESDraw_RectArraySubfigure::ColumnSeparation () const
{
return theColumnSeparation;
}
Standard_Real IGESDraw_RectArraySubfigure::RowSeparation () const
{
return theRowSeparation;
}
Standard_Real IGESDraw_RectArraySubfigure::RotationAngle () const
{
return theRotationAngle;
}
Standard_Boolean IGESDraw_RectArraySubfigure::DisplayFlag () const
{
return (thePositions.IsNull());
}
Standard_Integer IGESDraw_RectArraySubfigure::ListCount () const
{
return ( thePositions.IsNull() ? 0 : thePositions->Length() );
// Return 0 if HArray1 thePositions is NULL Handle
}
Standard_Boolean IGESDraw_RectArraySubfigure::DoDontFlag () const
{
return (theDoDontFlag);
}
Standard_Boolean IGESDraw_RectArraySubfigure::PositionNum
(const Standard_Integer Index) const
{
// Method : If thePositions array length is Zero return theDoDontFlag;
// else Search Index in to the Array. If 'Index' found in the
// array return theDoDontFlag else return !theDoDontFlag.
if (thePositions.IsNull()) return theDoDontFlag;
Standard_Integer I;
Standard_Integer up = thePositions->Upper();
for (I = 1; I <= up; I++) {
if (thePositions->Value(I) == Index) return theDoDontFlag;
}
return (! theDoDontFlag);
}
Standard_Integer IGESDraw_RectArraySubfigure::ListPosition
(const Standard_Integer Index) const
{
return thePositions->Value(Index);
// raise OutOfRange from Standard if Index is out-of-bound
// Exception NoSuchObject will be raised if thePositions == Null Handle
}