// 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 #include #include #include #include #include #include #include #include IMPLEMENT_STANDARD_RTTIEXT(IGESSelect_SelectLevelNumber, IFSelect_SelectExtract) IGESSelect_SelectLevelNumber::IGESSelect_SelectLevelNumber() {} void IGESSelect_SelectLevelNumber::SetLevelNumber(const Handle(IFSelect_IntParam)& levnum) { thelevnum = levnum; } Handle(IFSelect_IntParam) IGESSelect_SelectLevelNumber::LevelNumber() const { return thelevnum; } Standard_Boolean IGESSelect_SelectLevelNumber::Sort( const Standard_Integer /*rank*/, const Handle(Standard_Transient)& ent, const Handle(Interface_InterfaceModel)& /*model*/) const { DeclareAndCast(IGESData_IGESEntity, igesent, ent); if (igesent.IsNull()) return Standard_False; Standard_Integer numlev = 0; if (!thelevnum.IsNull()) numlev = thelevnum->Value(); DeclareAndCast(IGESGraph_DefinitionLevel, levelist, igesent->LevelList()); Standard_Integer level = igesent->Level(); if (levelist.IsNull()) return (level == numlev); // Cas d une liste if (numlev == 0) return Standard_False; Standard_Integer nb = levelist->NbPropertyValues(); for (Standard_Integer i = 1; i <= nb; i++) { level = levelist->LevelNumber(i); if (level == numlev) return Standard_True; } return Standard_False; } TCollection_AsciiString IGESSelect_SelectLevelNumber::ExtractLabel() const { char labl[50]; Standard_Integer numlev = 0; if (!thelevnum.IsNull()) numlev = thelevnum->Value(); if (numlev == 0) return TCollection_AsciiString("IGES Entity attached to no Level"); sprintf(labl, "IGES Entity, Level Number admitting %d", numlev); return TCollection_AsciiString(labl); }