0024002: Overall code and build procedure refactoring -- automatic
[occt.git] / src / IFSelect / IFSelect_SelectExtract.cxx
CommitLineData
973c2be1 1// Copyright (c) 1999-2014 OPEN CASCADE SAS
b311480e 2//
973c2be1 3// This file is part of Open CASCADE Technology software library.
b311480e 4//
d5f74e42 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
973c2be1 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.
b311480e 10//
973c2be1 11// Alternatively, this file may be used under the terms of Open CASCADE
12// commercial license or contractual agreement.
b311480e 13
7fd59977 14
42cf5bc1 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>
7fd59977 22
b311480e 23IFSelect_SelectExtract::IFSelect_SelectExtract ()
7fd59977 24 { thesort = Standard_True; }
25
26 Standard_Boolean IFSelect_SelectExtract::IsDirect () const
27 { return thesort; }
28
29 void IFSelect_SelectExtract::SetDirect (const Standard_Boolean direct)
30 { thesort = direct; }
31
32
33 Interface_EntityIterator IFSelect_SelectExtract::RootResult
34 (const Interface_Graph& G) const
35{
36 Interface_EntityIterator iter;
37 Interface_EntityIterator inputer = InputResult(G); // tient compte de tout
38 Handle(Interface_InterfaceModel) model = G.Model();
39 Standard_Integer rank = 0;
40 for (inputer.Start(); inputer.More(); inputer.Next()) {
41 Handle(Standard_Transient) ent = inputer.Value();
42 rank ++;
43 if (SortInGraph(rank,ent,G) == thesort) iter.GetOneItem(ent);
44 }
45 return iter;
46}
47
48
49 Standard_Boolean IFSelect_SelectExtract::SortInGraph
50 (const Standard_Integer rank, const Handle(Standard_Transient)& ent,
51 const Interface_Graph& G) const
52 { return Sort (rank, ent, G.Model()); }
53
54
55 TCollection_AsciiString IFSelect_SelectExtract::Label () const
56{
57 TCollection_AsciiString labl;
58 if ( thesort) labl.AssignCat("Picked: ");
59 if (!thesort) labl.AssignCat("Removed: ");
60 labl.AssignCat(ExtractLabel());
61 return labl;
62}