Salome HOME
updated copyright message
[modules/kernel.git] / src / SALOMEDSImpl / SALOMEDSImpl_AttributeTableOfReal.hxx
1 // Copyright (C) 2007-2023  CEA, EDF, OPEN CASCADE
2 //
3 // Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
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, or (at your option) any later version.
10 //
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.
15 //
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
19 //
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22
23 //  SALOME SALOMEDSImpl : data structure of SALOME and sources of Salome data server 
24 //  File   : SALOMEDSImpl_AttributeTableOfReal.hxx
25 //  Author : Michael Ponikarov
26 //  Module : SALOME
27 //
28 #ifndef _SALOMEDSImpl_AttributeTableOfReal_HeaderFile
29 #define _SALOMEDSImpl_AttributeTableOfReal_HeaderFile
30
31 #include "SALOMEDSImpl_Defines.hxx"
32 #include "DF_Attribute.hxx"
33 #include "DF_Label.hxx"      
34 #include "SALOMEDSImpl_GenericAttribute.hxx"
35 #include "SALOMEDSImpl_AttributeTable.hxx"
36
37 #include <string>
38 #include <vector>
39 #include <map>
40
41 class SALOMEDSIMPL_EXPORT SALOMEDSImpl_AttributeTableOfReal :
42   public SALOMEDSImpl_GenericAttribute, public SALOMEDSImpl_AttributeTable
43 {
44
45 public:
46   virtual std::string       Save();
47   virtual void              Load(const std::string&); 
48
49   static const std::string& GetID();
50   static SALOMEDSImpl_AttributeTableOfReal* Set(const DF_Label& label);
51
52   SALOMEDSImpl_AttributeTableOfReal();
53
54   void                     SetNbColumns(const int theNbColumns);
55   void                     SetTitle(const std::string& theTitle);
56   std::string              GetTitle() const;
57   void                     SetRowData(const int theRow, const std::vector<double>& theData);
58   std::vector<double>      GetRowData(const int theRow);
59   void                     SetRowTitle(const int theRow, const std::string& theTitle);
60   void                     SetRowUnit(const int theRow, const std::string& theUnit);
61   std::string              GetRowUnit(const int theRow) const;
62   void                     SetRowUnits(const std::vector<std::string>& theUnits);
63   std::vector<std::string> GetRowUnits();
64   void                     SetRowTitles(const std::vector<std::string>& theTitles);
65   std::vector<std::string> GetRowTitles();
66   std::string              GetRowTitle(const int theRow) const;
67   void                     SetColumnData(const int theColumn, const std::vector<double>& theData);
68   std::vector<double>      GetColumnData(const int theColumn);
69   void                     SetColumnTitle(const int theColumn, const std::string& theTitle);
70   void                     SetColumnTitles(const std::vector<std::string>& theTitles);
71   std::vector<std::string> GetColumnTitles();
72   std::string              GetColumnTitle(const int theColumn) const;
73   int                      GetNbRows() const;
74   int                      GetNbColumns() const;
75
76   void                     PutValue(const double& theValue, const int theRow, const int theColumn);
77   bool                     HasValue(const int theRow, const int theColumn);
78   double                   GetValue(const int theRow, const int theColumn);
79   void                     RemoveValue(const int theRow, const int theColumn);
80   const std::string&       ID() const;
81   void                     Restore(DF_Attribute* with);
82   DF_Attribute*            NewEmpty() const;
83   void                     Paste(DF_Attribute* into);
84
85   std::vector<int>         GetSetRowIndices(const int theRow);
86   std::vector<int>         GetSetColumnIndices(const int theColumn);
87
88   std::vector<int>         SortRow(const int theRow, SortOrder sortOrder, SortPolicy sortPolicy);
89   std::vector<int>         SortColumn(const int theColumn, SortOrder sortOrder, SortPolicy sortPolicy);
90   std::vector<int>         SortByRow(const int theRow, SortOrder sortOrder, SortPolicy sortPolicy);
91   std::vector<int>         SortByColumn(const int theColumn, SortOrder sortOrder, SortPolicy sortPolicy);
92
93   void                     SwapCells(const int theRow1, const int theColumn1, const int theRow2, const int theColumn2);
94   void                     SwapRows(const int theRow1, const int theRow2);
95   void                     SwapColumns(const int theColumn1, const int theColumn2);
96
97   ~SALOMEDSImpl_AttributeTableOfReal() {}
98
99 private: 
100   std::map<int, double>    myTable;
101   std::string              myTitle;
102   std::vector<std::string> myRows;
103   std::vector<std::string> myCols;
104   int                      myNbRows;
105   int                      myNbColumns;
106 };
107
108 #endif