1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-10 18:51:21 +03:00
occt/src/IGESSelect/IGESSelect_DispPerDrawing.cxx
abv 92efcf78a6 0026936: Drawbacks of inlining in new type system in OCCT 7.0 -- automatic
Automatic restore of IMPLEMENT_STANDARD_RTTIEXT macro (upgrade -rtti)
2015-12-04 14:15:06 +03:00

74 lines
2.5 KiB
C++

// 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 <IFGraph_SubPartsIterator.hxx>
#include <IFSelect_PacketList.hxx>
#include <IFSelect_Selection.hxx>
#include <IGESData_IGESModel.hxx>
#include <IGESSelect_DispPerDrawing.hxx>
#include <IGESSelect_ViewSorter.hxx>
#include <Interface_EntityIterator.hxx>
#include <Interface_Graph.hxx>
#include <Interface_Macros.hxx>
#include <Standard_Type.hxx>
#include <TCollection_AsciiString.hxx>
IMPLEMENT_STANDARD_RTTIEXT(IGESSelect_DispPerDrawing,IFSelect_Dispatch)
IGESSelect_DispPerDrawing::IGESSelect_DispPerDrawing ()
{ thesorter = new IGESSelect_ViewSorter; }
TCollection_AsciiString IGESSelect_DispPerDrawing::Label () const
{
return TCollection_AsciiString("One File per Drawing");
}
void IGESSelect_DispPerDrawing::Packets
(const Interface_Graph& G, IFGraph_SubPartsIterator& packs) const
{
if (FinalSelection().IsNull()) return;
Interface_EntityIterator list = FinalSelection()->UniqueResult(G);
thesorter->SetModel (GetCasted(IGESData_IGESModel,G.Model()));
thesorter->Clear();
thesorter->AddList (list.Content());
thesorter->SortDrawings(G);
Handle(IFSelect_PacketList) sets = thesorter->Sets(Standard_True);
packs.SetLoad();
Standard_Integer nb = sets->NbPackets();
for (Standard_Integer i = 1; i <= nb; i ++) {
packs.AddPart();
packs.GetFromIter (sets->Entities(i));
}
}
Standard_Boolean IGESSelect_DispPerDrawing::CanHaveRemainder () const
{ return Standard_True; }
Interface_EntityIterator IGESSelect_DispPerDrawing::Remainder
(const Interface_Graph& G) const
{
if (thesorter->NbEntities() == 0) {
Interface_EntityIterator list;
if (FinalSelection().IsNull()) return list;
list = FinalSelection()->UniqueResult(G);
thesorter->Clear();
thesorter->AddList (list.Content());
thesorter->SortDrawings(G);
}
return thesorter->Sets(Standard_True)->Duplicated (0,Standard_False);
}