2 // Class : Implementation des groupes
4 // Copyright (C) 2009-2012 CEA/DEN, EDF R&D
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
26 #include "hexa_base.hxx"
33 Group (cpchar nom, EnumGroup grp);
36 void setName (cpchar nom) { grp_name = nom ; }
37 cpchar getName () { return grp_name.c_str () ; }
38 char* getNextName (pchar buffer);
39 EnumGroup getKind () { return grp_kind ; }
40 int addElement (EltBase* elt);
41 int removeElement (EltBase* elt);
42 int findElement (EltBase* elt);
43 int removeElement (int nro);
44 EltBase* getElement (int nro) { return grp_table [nro] ; }
45 int countElement () { return grp_table.size () ; }
46 void clearElement () { grp_table.clear () ; }
48 void saveXml (XmlWriter* xml);
49 EnumElt getTypeElt () { return grp_typelt ; }
51 static EnumGroup getKind (cpchar kind);
52 static EnumGroup getKind (const string& k) { return getKind (k.c_str());}
56 static int last_grp_id;
60 std::vector <EltBase*> grp_table;