1 // Copyright (C) 2005 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
2 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
4 // This library is free software; you can redistribute it and/or
5 // modify it under the terms of the GNU Lesser General Public
6 // License as published by the Free Software Foundation; either
7 // version 2.1 of the License.
9 // This library is distributed in the hope that it will be useful
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 // Lesser General Public License for more details.
14 // You should have received a copy of the GNU Lesser General Public
15 // License along with this library; if not, write to the Free Software
16 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 // See http://www.salome-platform.org/
20 // File : SALOMEDS_AttributeTableOfReal.cxx
21 // Author : Sergey RUIN
24 #include "SALOMEDS_AttributeTableOfReal.hxx"
25 #include "SALOMEDS.hxx"
27 #include <TCollection_AsciiString.hxx>
28 #include <TCollection_ExtendedString.hxx>
29 #include <TColStd_HSequenceOfInteger.hxx>
30 #include <TColStd_HSequenceOfReal.hxx>
31 #include <TColStd_HSequenceOfExtendedString.hxx>
34 SALOMEDS_AttributeTableOfReal::SALOMEDS_AttributeTableOfReal
35 (const Handle(SALOMEDSImpl_AttributeTableOfReal)& theAttr)
36 :SALOMEDS_GenericAttribute(theAttr)
39 SALOMEDS_AttributeTableOfReal::SALOMEDS_AttributeTableOfReal(SALOMEDS::AttributeTableOfReal_ptr theAttr)
40 :SALOMEDS_GenericAttribute(theAttr)
43 SALOMEDS_AttributeTableOfReal::~SALOMEDS_AttributeTableOfReal()
47 void SALOMEDS_AttributeTableOfReal::SetTitle(const std::string& theTitle)
51 SALOMEDS::Locker lock;
52 Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->SetTitle((char*)theTitle.c_str());
54 else SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetTitle(theTitle.c_str());
57 std::string SALOMEDS_AttributeTableOfReal::GetTitle()
61 SALOMEDS::Locker lock;
62 aStr = TCollection_AsciiString(Handle(SALOMEDSImpl_AttributeTableOfReal)::
63 DownCast(_local_impl)->GetTitle()).ToCString();
65 else aStr = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetTitle();
69 void SALOMEDS_AttributeTableOfReal::SetRowTitle(int theIndex, const std::string& theTitle)
73 SALOMEDS::Locker lock;
74 Handle(SALOMEDSImpl_AttributeTableOfReal)::
75 DownCast(_local_impl)->SetRowTitle(theIndex, (char*)theTitle.c_str());
77 else SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetRowTitle(theIndex, theTitle.c_str());
80 void SALOMEDS_AttributeTableOfReal::SetRowTitles(const std::vector<std::string>& theTitles)
83 int aLength = theTitles.size(), i;
86 SALOMEDS::Locker lock;
87 Handle(TColStd_HSequenceOfExtendedString) aSeq = new TColStd_HSequenceOfExtendedString;
88 for (i = 0; i < aLength; i++) aSeq->Append((char*)theTitles[i].c_str());
89 Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->SetRowTitles(aSeq);
92 SALOMEDS::StringSeq_var aSeq = new SALOMEDS::StringSeq();
93 aSeq->length(aLength);
94 for (i = 0; i < aLength; i++) aSeq[i] = (char*)theTitles[i].c_str();
95 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetRowTitles(aSeq);
99 std::vector<std::string> SALOMEDS_AttributeTableOfReal::GetRowTitles()
101 std::vector<std::string> aVector;
104 SALOMEDS::Locker lock;
105 Handle(TColStd_HSequenceOfExtendedString) aSeq;
106 aSeq = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetRowTitles();
107 aLength = aSeq->Length();
108 for (i = 1; i <= aLength; i++) aVector.push_back(TCollection_AsciiString(aSeq->Value(i)).ToCString());
111 SALOMEDS::StringSeq_var aSeq = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetRowTitles();
112 aLength = aSeq->length();
113 for (i = 0; i < aLength; i++) aVector.push_back((char*)aSeq[i].in());
118 void SALOMEDS_AttributeTableOfReal::SetColumnTitle(int theIndex, const std::string& theTitle)
122 SALOMEDS::Locker lock;
123 Handle(SALOMEDSImpl_AttributeTableOfReal)::
124 DownCast(_local_impl)->SetColumnTitle(theIndex, (char*)theTitle.c_str());
126 else SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetColumnTitle(theIndex, theTitle.c_str());
129 void SALOMEDS_AttributeTableOfReal::SetColumnTitles(const std::vector<std::string>& theTitles)
131 int aLength = theTitles.size(), i;
134 SALOMEDS::Locker lock;
135 Handle(TColStd_HSequenceOfExtendedString) aSeq = new TColStd_HSequenceOfExtendedString;
136 for (i = 0; i < aLength; i++) aSeq->Append((char*)theTitles[i].c_str());
137 Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->SetColumnTitles(aSeq);
140 SALOMEDS::StringSeq_var aSeq = new SALOMEDS::StringSeq();
141 aSeq->length(aLength);
142 for (i = 0; i < aLength; i++) aSeq[i] = (char*)theTitles[i].c_str();
143 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetColumnTitles(aSeq);
147 std::vector<std::string> SALOMEDS_AttributeTableOfReal::GetColumnTitles()
149 std::vector<std::string> aVector;
152 SALOMEDS::Locker lock;
153 Handle(TColStd_HSequenceOfExtendedString) aSeq;
154 aSeq = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetColumnTitles();
155 aLength = aSeq->Length();
156 for (i = 1; i <= aLength; i++) aVector.push_back(TCollection_AsciiString(aSeq->Value(i)).ToCString());
159 SALOMEDS::StringSeq_var aSeq = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetColumnTitles();
160 aLength = aSeq->length();
161 for (i = 0; i < aLength; i++) aVector.push_back((char*)aSeq[i].in());
166 void SALOMEDS_AttributeTableOfReal::SetRowUnit(int theIndex, const std::string& theUnit)
170 SALOMEDS::Locker lock;
171 Handle(SALOMEDSImpl_AttributeTableOfReal)::
172 DownCast(_local_impl)->SetRowUnit(theIndex, (char*)theUnit.c_str());
174 else SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetRowUnit(theIndex, theUnit.c_str());
177 void SALOMEDS_AttributeTableOfReal::SetRowUnits(const std::vector<std::string>& theUnits)
179 int aLength = theUnits.size(), i;
182 SALOMEDS::Locker lock;
183 Handle(TColStd_HSequenceOfExtendedString) aSeq = new TColStd_HSequenceOfExtendedString;
184 for (i = 0; i < aLength; i++) aSeq->Append((char*)theUnits[i].c_str());
185 Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->SetRowUnits(aSeq);
188 SALOMEDS::StringSeq_var aSeq = new SALOMEDS::StringSeq();
189 aSeq->length(aLength);
190 for (i = 0; i < aLength; i++) aSeq[i] = (char*)theUnits[i].c_str();
191 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetRowUnits(aSeq);
195 std::vector<std::string> SALOMEDS_AttributeTableOfReal::GetRowUnits()
197 std::vector<std::string> aVector;
200 SALOMEDS::Locker lock;
201 Handle(TColStd_HSequenceOfExtendedString) aSeq;
202 aSeq = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetRowUnits();
203 aLength = aSeq->Length();
204 for (i = 1; i <= aLength; i++) aVector.push_back(TCollection_AsciiString(aSeq->Value(i)).ToCString());
207 SALOMEDS::StringSeq_var aSeq = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetRowUnits();
208 aLength = aSeq->length();
209 for (i = 0; i < aLength; i++) aVector.push_back(TCollection_AsciiString((char*)aSeq[i].in()).ToCString());
214 int SALOMEDS_AttributeTableOfReal::GetNbRows()
218 SALOMEDS::Locker lock;
219 aNb = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetNbRows();
221 else aNb = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetNbRows();
225 int SALOMEDS_AttributeTableOfReal::GetNbColumns()
229 SALOMEDS::Locker lock;
230 aNb = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetNbColumns();
232 else aNb = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetNbColumns();
236 void SALOMEDS_AttributeTableOfReal::AddRow(const std::vector<double>& theData)
238 int aLength = theData.size(), i;
241 SALOMEDS::Locker lock;
242 Handle(SALOMEDSImpl_AttributeTableOfReal) aTable;
243 aTable = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl);
244 Handle(TColStd_HSequenceOfReal) aRow = new TColStd_HSequenceOfReal;
245 for (int i = 0; i < aLength; i++) aRow->Append(theData[i]);
247 aTable->SetRowData(aTable->GetNbRows() + 1, aRow);
250 throw SALOMEDS::AttributeTableOfReal::IncorrectArgumentLength();
254 SALOMEDS::DoubleSeq_var aSeq = new SALOMEDS::DoubleSeq();
255 aSeq->length(aLength);
256 for (i = 0; i < aLength; i++) aSeq[i] = theData[i];
257 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->AddRow(aSeq);
261 void SALOMEDS_AttributeTableOfReal::SetRow(int theRow, const std::vector<double>& theData)
263 int aLength = theData.size(), i;
266 SALOMEDS::Locker lock;
267 Handle(SALOMEDSImpl_AttributeTableOfReal) aTable;
268 aTable = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl);
269 Handle(TColStd_HSequenceOfReal) aRow = new TColStd_HSequenceOfReal;
270 for (int i = 0; i < aLength; i++) aRow->Append(theData[i]);
272 aTable->SetRowData(theRow, aRow);
275 throw SALOMEDS::AttributeTableOfReal::IncorrectArgumentLength();
279 SALOMEDS::DoubleSeq_var aSeq = new SALOMEDS::DoubleSeq();
280 aSeq->length(aLength);
281 for (i = 0; i < aLength; i++) aSeq[i] = theData[i];
282 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetRow(theRow, aSeq);
286 std::vector<double> SALOMEDS_AttributeTableOfReal::GetRow(int theRow)
288 std::vector<double> aVector;
291 SALOMEDS::Locker lock;
292 Handle(TColStd_HSequenceOfReal) aRow;
293 aRow = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetRowData(theRow);
294 aLength = aRow->Length();
295 for (i = 1; i <= aLength; i++) aVector.push_back(aRow->Value(i));
298 SALOMEDS::DoubleSeq_var aRow = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetRow(theRow);
299 aLength = aRow->length();
300 for (i = 0; i < aLength; i++) aVector.push_back(aRow[i]);
306 void SALOMEDS_AttributeTableOfReal::AddColumn(const std::vector<double>& theData)
308 int aLength = theData.size(), i;
311 SALOMEDS::Locker lock;
312 Handle(SALOMEDSImpl_AttributeTableOfReal) aTable;
313 aTable = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl);
314 Handle(TColStd_HSequenceOfReal) aColumn = new TColStd_HSequenceOfReal;
315 for (int i = 0; i < aLength; i++) aColumn->Append(theData[i]);
317 aTable->SetColumnData(aTable->GetNbColumns() + 1, aColumn);
320 throw SALOMEDS::AttributeTableOfReal::IncorrectArgumentLength();
324 SALOMEDS::DoubleSeq_var aColumn = new SALOMEDS::DoubleSeq();
325 aColumn->length(aLength);
326 for (i = 0; i < aLength; i++) aColumn[i] = theData[i];
327 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->AddColumn(aColumn);
331 void SALOMEDS_AttributeTableOfReal::SetColumn(int theColumn, const std::vector<double>& theData)
333 int aLength = theData.size(), i;
336 SALOMEDS::Locker lock;
337 Handle(SALOMEDSImpl_AttributeTableOfReal) aTable;
338 aTable = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl);
339 Handle(TColStd_HSequenceOfReal) aColumn = new TColStd_HSequenceOfReal;
340 for (int i = 0; i < aLength; i++) aColumn->Append(theData[i]);
342 aTable->SetRowData(theColumn, aColumn);
345 throw SALOMEDS::AttributeTableOfReal::IncorrectArgumentLength();
349 SALOMEDS::DoubleSeq_var aColumn = new SALOMEDS::DoubleSeq();
350 aColumn->length(aLength);
351 for (i = 0; i < aLength; i++) aColumn[i] = theData[i];
352 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetRow(theColumn, aColumn);
356 std::vector<double> SALOMEDS_AttributeTableOfReal::GetColumn(int theColumn)
358 std::vector<double> aVector;
361 SALOMEDS::Locker lock;
362 Handle(TColStd_HSequenceOfReal) aColumn;
363 aColumn = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetColumnData(theColumn);
364 aLength = aColumn->Length();
365 for (i = 1; i <= aLength; i++) aVector.push_back(aColumn->Value(i));
368 SALOMEDS::DoubleSeq_var aColumn = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetColumn(theColumn);
369 aLength = aColumn->length();
370 for (i = 0; i < aLength; i++) aVector.push_back(aColumn[i]);
375 void SALOMEDS_AttributeTableOfReal::PutValue(double theValue, int theRow, int theColumn)
379 SALOMEDS::Locker lock;
381 Handle(SALOMEDSImpl_AttributeTableOfReal)::
382 DownCast(_local_impl)->PutValue(theValue, theRow, theColumn);
385 throw SALOMEDS::AttributeTableOfReal::IncorrectIndex();
389 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->PutValue(theValue, theRow, theColumn);
393 bool SALOMEDS_AttributeTableOfReal::HasValue(int theRow, int theColumn)
397 SALOMEDS::Locker lock;
398 ret = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->HasValue(theRow, theColumn);
400 else ret = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->HasValue(theRow, theColumn);
404 double SALOMEDS_AttributeTableOfReal::GetValue(int theRow, int theColumn)
408 SALOMEDS::Locker lock;
410 aValue = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetValue(theRow, theColumn);
413 throw SALOMEDS::AttributeTableOfReal::IncorrectIndex();
417 aValue = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetValue(theRow, theColumn);
422 std::vector<int> SALOMEDS_AttributeTableOfReal::GetRowSetIndices(int theRow)
424 std::vector<int> aVector;
427 SALOMEDS::Locker lock;
428 Handle(TColStd_HSequenceOfInteger) aSet;
429 aSet = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetSetRowIndices(theRow);
430 aLength = aSet->Length();
431 for (i = 1; i <= aLength; i++) aVector.push_back(aSet->Value(i));
434 SALOMEDS::LongSeq_var aSet = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetRowSetIndices(theRow);
435 aLength = aSet->length();
436 for (i = 0; i < aLength; i++) aVector.push_back(aSet[i]);
441 void SALOMEDS_AttributeTableOfReal::SetNbColumns(int theNbColumns)
444 SALOMEDS::Locker lock;
445 Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->SetNbColumns(theNbColumns);
447 else SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetNbColumns(theNbColumns);