0026937: Eliminate NO_CXX_EXCEPTION macro support
[occt.git] / src / IGESAppli / IGESAppli_NodalResults.cxx
1 // Created by: CKY / Contract Toubro-Larsen
2 // Copyright (c) 1993-1999 Matra Datavision
3 // Copyright (c) 1999-2014 OPEN CASCADE SAS
4 //
5 // This file is part of Open CASCADE Technology software library.
6 //
7 // This library is free software; you can redistribute it and/or modify it under
8 // the terms of the GNU Lesser General Public License version 2.1 as published
9 // by the Free Software Foundation, with special exception defined in the file
10 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
11 // distribution for complete text of the license and disclaimer of any warranty.
12 //
13 // Alternatively, this file may be used under the terms of Open CASCADE
14 // commercial license or contractual agreement.
15
16 //--------------------------------------------------------------------
17 //--------------------------------------------------------------------
18
19 #include <IGESAppli_NodalResults.hxx>
20 #include <IGESAppli_Node.hxx>
21 #include <IGESDimen_GeneralNote.hxx>
22 #include <Standard_DimensionMismatch.hxx>
23 #include <Standard_OutOfRange.hxx>
24 #include <Standard_Type.hxx>
25 #include <TColStd_HArray1OfReal.hxx>
26
27 IMPLEMENT_STANDARD_RTTIEXT(IGESAppli_NodalResults,IGESData_IGESEntity)
28
29 IGESAppli_NodalResults::IGESAppli_NodalResults ()    {  }
30
31
32 // Data : Col -> // Nodes.  Row : Data per Node
33
34     void  IGESAppli_NodalResults::Init
35   (const Handle(IGESDimen_GeneralNote)&    aNote,
36    const Standard_Integer aNumber, const Standard_Real aTime,
37    const Handle(TColStd_HArray1OfInteger)& allNodeIdentifiers,
38    const Handle(IGESAppli_HArray1OfNode)&  allNodes,
39    const Handle(TColStd_HArray2OfReal)&    allData)
40 {
41   if (allNodes->Lower()   != 1 || allNodeIdentifiers->Lower() != 1 ||
42       allNodes->Length()  != allNodeIdentifiers->Length() ||
43       allData->LowerCol() != 1 || allData->LowerRow() != 1 ||
44       allNodes->Length()  != allData->UpperRow() )
45     throw Standard_DimensionMismatch("IGESAppli_NodalResults : Init");
46   theNote            = aNote;
47   theSubCaseNum      = aNumber;
48   theTime            = aTime;
49   theNodeIdentifiers = allNodeIdentifiers;
50   theNodes           = allNodes;
51   theData            = allData;
52   InitTypeAndForm(146,FormNumber());
53 // FormNumber -> Type of the Results
54 }
55
56     void  IGESAppli_NodalResults::SetFormNumber (const Standard_Integer form)
57 {
58   if (form < 0 || form > 34) throw Standard_OutOfRange("IGESAppli_NodalResults : SetFormNumber");
59   InitTypeAndForm(146,form);
60 }
61
62
63     Handle(IGESDimen_GeneralNote)  IGESAppli_NodalResults::Note () const
64 {
65   return theNote;
66 }
67
68     Handle(IGESAppli_Node)  IGESAppli_NodalResults::Node
69   (const Standard_Integer Index) const
70 {
71   return theNodes->Value(Index);
72 }
73
74     Standard_Integer  IGESAppli_NodalResults::NbNodes () const
75 {
76   return theNodes->Length();
77 }
78
79     Standard_Integer  IGESAppli_NodalResults::SubCaseNumber () const
80 {
81   return theSubCaseNum;
82 }
83
84     Standard_Real  IGESAppli_NodalResults::Time () const
85 {
86   return theTime;
87 }
88
89     Standard_Integer  IGESAppli_NodalResults::NbData () const
90 {
91   return theData->RowLength();
92 }
93
94     Standard_Integer  IGESAppli_NodalResults::NodeIdentifier
95   (const Standard_Integer Index) const
96 {
97   return theNodeIdentifiers->Value(Index);
98 }
99
100     Standard_Real  IGESAppli_NodalResults::Data
101   (const Standard_Integer NodeNum, const Standard_Integer DataNum) const
102 {
103   return theData->Value(NodeNum,DataNum);
104 }