db554e2e70f1cc5b80095d08f012425368e38194
[occt.git] / src / IGESSelect / IGESSelect_SelectFromSingleView.cxx
1 #include <IGESSelect_SelectFromSingleView.ixx>
2 #include <IGESData_IGESEntity.hxx>
3 #include <Interface_Macros.hxx>
4
5
6
7     IGESSelect_SelectFromSingleView::IGESSelect_SelectFromSingleView ()    {  }
8
9
10     Interface_EntityIterator  IGESSelect_SelectFromSingleView::RootResult
11   (const Interface_Graph& G) const
12 {
13   Interface_EntityIterator list;
14   Interface_EntityIterator views = InputResult(G);
15   if (views.NbEntities() == 0) return list;
16   Standard_Integer nb = G.Size();
17   char* nums = new char[nb+1];
18   Standard_Integer i; // svv Jan11 2000 : porting on DEC
19   for (i = 1; i <= nb; i ++) nums[i] = 0;
20   for (views.Start(); views.More(); views.Next()) {
21     Standard_Integer nv = G.EntityNumber(views.Value());
22     if (nv > 0 && nv <= nb) nums[nv] = 1;
23   }
24   for (i = 1; i <= nb; i ++) {
25 //    if (!G.IsPresent(i)) continue;
26     DeclareAndCast(IGESData_IGESEntity,igesent,G.Entity(i));
27     if (igesent.IsNull()) continue;
28     Standard_Integer nv = G.EntityNumber (igesent->View());
29     if (nv > 0 && nv <= nb) list.GetOneItem(igesent);
30   }
31   delete nums;
32   return list;
33 }
34
35
36     TCollection_AsciiString  IGESSelect_SelectFromSingleView::Label () const
37 {  return TCollection_AsciiString ("Entities attached to a single View");  }