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 for (i = 0; i < aLength; i++) aVector.push_back(aRow[i]);
305 void SALOMEDS_AttributeTableOfReal::AddColumn(const std::vector<double>& theData)
307 int aLength = theData.size(), i;
310 SALOMEDS::Locker lock;
311 Handle(SALOMEDSImpl_AttributeTableOfReal) aTable;
312 aTable = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl);
313 Handle(TColStd_HSequenceOfReal) aColumn = new TColStd_HSequenceOfReal;
314 for (int i = 0; i < aLength; i++) aColumn->Append(theData[i]);
316 aTable->SetColumnData(aTable->GetNbColumns() + 1, aColumn);
319 throw SALOMEDS::AttributeTableOfReal::IncorrectArgumentLength();
323 SALOMEDS::DoubleSeq_var aColumn = new SALOMEDS::DoubleSeq();
324 aColumn->length(aLength);
325 for (i = 0; i < aLength; i++) aColumn[i] = theData[i];
326 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->AddColumn(aColumn);
330 void SALOMEDS_AttributeTableOfReal::SetColumn(int theColumn, const std::vector<double>& theData)
332 int aLength = theData.size(), i;
335 SALOMEDS::Locker lock;
336 Handle(SALOMEDSImpl_AttributeTableOfReal) aTable;
337 aTable = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl);
338 Handle(TColStd_HSequenceOfReal) aColumn = new TColStd_HSequenceOfReal;
339 for (int i = 0; i < aLength; i++) aColumn->Append(theData[i]);
341 aTable->SetRowData(theColumn, aColumn);
344 throw SALOMEDS::AttributeTableOfReal::IncorrectArgumentLength();
348 SALOMEDS::DoubleSeq_var aColumn = new SALOMEDS::DoubleSeq();
349 aColumn->length(aLength);
350 for (i = 0; i < aLength; i++) aColumn[i] = theData[i];
351 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetRow(theColumn, aColumn);
355 std::vector<double> SALOMEDS_AttributeTableOfReal::GetColumn(int theColumn)
357 std::vector<double> aVector;
360 SALOMEDS::Locker lock;
361 Handle(TColStd_HSequenceOfReal) aColumn;
362 aColumn = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetColumnData(theColumn);
363 aLength = aColumn->Length();
364 for (i = 1; i <= aLength; i++) aVector.push_back(aColumn->Value(i));
367 SALOMEDS::DoubleSeq_var aColumn = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetColumn(theColumn);
368 for (i = 0; i < aLength; i++) aVector.push_back(aColumn[i]);
373 void SALOMEDS_AttributeTableOfReal::PutValue(double theValue, int theRow, int theColumn)
377 SALOMEDS::Locker lock;
379 Handle(SALOMEDSImpl_AttributeTableOfReal)::
380 DownCast(_local_impl)->PutValue(theValue, theRow, theColumn);
383 throw SALOMEDS::AttributeTableOfReal::IncorrectIndex();
387 SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->PutValue(theValue, theRow, theColumn);
391 bool SALOMEDS_AttributeTableOfReal::HasValue(int theRow, int theColumn)
395 SALOMEDS::Locker lock;
396 ret = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->HasValue(theRow, theColumn);
398 else ret = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->HasValue(theRow, theColumn);
402 double SALOMEDS_AttributeTableOfReal::GetValue(int theRow, int theColumn)
406 SALOMEDS::Locker lock;
408 aValue = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetValue(theRow, theColumn);
411 throw SALOMEDS::AttributeTableOfReal::IncorrectIndex();
415 aValue = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetValue(theRow, theColumn);
420 std::vector<int> SALOMEDS_AttributeTableOfReal::GetRowSetIndices(int theRow)
422 std::vector<int> aVector;
425 SALOMEDS::Locker lock;
426 Handle(TColStd_HSequenceOfInteger) aSet;
427 aSet = Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->GetSetRowIndices(theRow);
428 aLength = aSet->Length();
429 for (i = 1; i <= aLength; i++) aVector.push_back(aSet->Value(i));
432 SALOMEDS::LongSeq_var aSet = SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->GetRowSetIndices(theRow);
433 for (i = 0; i < aLength; i++) aVector.push_back(aSet[i]);
438 void SALOMEDS_AttributeTableOfReal::SetNbColumns(int theNbColumns)
441 SALOMEDS::Locker lock;
442 Handle(SALOMEDSImpl_AttributeTableOfReal)::DownCast(_local_impl)->SetNbColumns(theNbColumns);
444 else SALOMEDS::AttributeTableOfReal::_narrow(_corba_impl)->SetNbColumns(theNbColumns);