// 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_SelectSingleViewFrom, IFSelect_SelectDeduct) IGESSelect_SelectSingleViewFrom::IGESSelect_SelectSingleViewFrom() {} Standard_Boolean IGESSelect_SelectSingleViewFrom::HasUniqueResult() const { return Standard_True; } Interface_EntityIterator IGESSelect_SelectSingleViewFrom::RootResult(const Interface_Graph& G) const { Handle(IGESSelect_ViewSorter) sorter = new IGESSelect_ViewSorter; sorter->SetModel(GetCasted(IGESData_IGESModel, G.Model())); sorter->Clear(); sorter->AddList(InputResult(G).Content()); sorter->SortSingleViews(Standard_True); Interface_EntityIterator list; Standard_Integer nb = sorter->NbSets(Standard_True); for (Standard_Integer i = 1; i <= nb; i++) list.GetOneItem(sorter->SetItem(i, Standard_True)); return list; } TCollection_AsciiString IGESSelect_SelectSingleViewFrom::Label() const { return TCollection_AsciiString("Single Views attached"); }