1 // Copyright (c) 1999-2014 OPEN CASCADE SAS
3 // This file is part of Open CASCADE Technology software library.
5 // This library is free software; you can redistribute it and/or modify it under
6 // the terms of the GNU Lesser General Public License version 2.1 as published
7 // by the Free Software Foundation, with special exception defined in the file
8 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
9 // distribution for complete text of the license and disclaimer of any warranty.
11 // Alternatively, this file may be used under the terms of Open CASCADE
12 // commercial license or contractual agreement.
15 #include <IFSelect_SelectExtract.hxx>
16 #include <Interface_EntityIterator.hxx>
17 #include <Interface_Graph.hxx>
18 #include <Interface_InterfaceModel.hxx>
19 #include <Standard_Transient.hxx>
20 #include <Standard_Type.hxx>
21 #include <TCollection_AsciiString.hxx>
23 IMPLEMENT_STANDARD_RTTIEXT(IFSelect_SelectExtract,IFSelect_SelectDeduct)
25 IFSelect_SelectExtract::IFSelect_SelectExtract ()
26 { thesort = Standard_True; }
28 Standard_Boolean IFSelect_SelectExtract::IsDirect () const
31 void IFSelect_SelectExtract::SetDirect (const Standard_Boolean direct)
35 Interface_EntityIterator IFSelect_SelectExtract::RootResult
36 (const Interface_Graph& G) const
38 Interface_EntityIterator iter;
39 Interface_EntityIterator inputer = InputResult(G); // tient compte de tout
40 Handle(Interface_InterfaceModel) model = G.Model();
41 Standard_Integer rank = 0;
42 for (inputer.Start(); inputer.More(); inputer.Next()) {
43 Handle(Standard_Transient) ent = inputer.Value();
45 if (SortInGraph(rank,ent,G) == thesort) iter.GetOneItem(ent);
51 Standard_Boolean IFSelect_SelectExtract::SortInGraph
52 (const Standard_Integer rank, const Handle(Standard_Transient)& ent,
53 const Interface_Graph& G) const
54 { return Sort (rank, ent, G.Model()); }
57 TCollection_AsciiString IFSelect_SelectExtract::Label () const
59 TCollection_AsciiString labl;
60 if ( thesort) labl.AssignCat("Picked: ");
61 if (!thesort) labl.AssignCat("Removed: ");
62 labl.AssignCat(ExtractLabel());