Ice Sheet System Model  4.18
Code documentation
DoubleInput2.cpp
Go to the documentation of this file.
1 
5 #ifdef HAVE_CONFIG_H
6  #include <config.h>
7 #else
8 #error "Cannot compile with HAVE_CONFIG_H symbol! run configure first!"
9 #endif
10 
11 #include "../classes.h"
12 #include "../../shared/shared.h"
13 #include "./DoubleInput2.h"
14 
15 /*DoubleInput2 constructors and destructor*/
17  this->size = -1;
18  this->values = NULL;
19 }
20 /*}}}*/
21 DoubleInput2::DoubleInput2(int size_in){/*{{{*/
22  _assert_(size_in>0);
23  _assert_(size_in<1e11);
24  this->size = size_in;
25  this->values = xNew<IssmDouble>(size_in);
26 }
27 /*}}}*/
29  xDelete<IssmDouble>(this->values);
30 }
31 /*}}}*/
32 
33 /*Object virtual functions definitions:*/
35 
36  DoubleInput2* output = new DoubleInput2(this->size);
37  xMemCpy<IssmDouble>(output->values,this->values,this->size);
38 
39  return output;
40 }
41 /*}}}*/
42 void DoubleInput2::DeepEcho(void){/*{{{*/
43 
44  _printf_("DoubleInput2 Echo:\n");
45  _printf_(" Size: "<<size<<"\n");
46  printarray(this->values,this->size);
47  //_printf_(setw(15)<<" DoubleInput2 "<<setw(25)<<left<<EnumToStringx(this->enum_type)<<" "<<(value?"true":"false") << "\n");
48 }
49 /*}}}*/
50 void DoubleInput2::Echo(void){/*{{{*/
51  this->DeepEcho();
52 }
53 /*}}}*/
54 int DoubleInput2::Id(void){ return -1; }/*{{{*/
55 /*}}}*/
56 void DoubleInput2::Marshall(char** pmarshalled_data,int* pmarshalled_data_size, int marshall_direction){ /*{{{*/
57 
59 
60  MARSHALLING(this->size);
61  if(this->size > 0){
63  }
64  else this->values = NULL;
65 
66 }
67 /*}}}*/
68 int DoubleInput2::ObjectEnum(void){/*{{{*/
69 
70  return DoubleInput2Enum;
71 
72 }
73 /*}}}*/
74 
75 /*DoubleInput2 management*/
76 void DoubleInput2::GetInput(IssmDouble* pvalue,int index){/*{{{*/
77 
78  _assert_(index>=0);
79  _assert_(index<this->size);
80 
81  *pvalue = this->values[index];
82 }
83 /*}}}*/
84 void DoubleInput2::SetInput(int index,IssmDouble value){/*{{{*/
85 
86  _assert_(index>=0);
87  _assert_(index<this->size);
88 
89  this->values[index] = value;
90 }
91 /*}}}*/
92 
93 /*Object functions*/
DoubleInput2::values
IssmDouble * values
Definition: DoubleInput2.h:11
DoubleInput2::copy
Input2 * copy()
Definition: DoubleInput2.cpp:34
_assert_
#define _assert_(ignore)
Definition: exceptions.h:37
DoubleInput2::SetInput
void SetInput(int index, IssmDouble value)
Definition: DoubleInput2.cpp:84
IssmDouble
double IssmDouble
Definition: types.h:37
DoubleInput2::Id
int Id()
Definition: DoubleInput2.cpp:54
_printf_
#define _printf_(StreamArgs)
Definition: Print.h:22
MARSHALLING_ENUM
#define MARSHALLING_ENUM(EN)
Definition: Marshalling.h:14
DoubleInput2::Marshall
void Marshall(char **pmarshalled_data, int *pmarshalled_data_size, int marshall_direction)
Definition: DoubleInput2.cpp:56
DoubleInput2Enum
@ DoubleInput2Enum
Definition: EnumDefinitions.h:997
DoubleInput2::DoubleInput2
DoubleInput2()
Definition: DoubleInput2.cpp:16
MARSHALLING_DYNAMIC
#define MARSHALLING_DYNAMIC(FIELD, TYPE, SIZE)
Definition: Marshalling.h:61
DoubleInput2
Definition: DoubleInput2.h:7
DoubleInput2::Echo
void Echo()
Definition: DoubleInput2.cpp:50
DoubleInput2::ObjectEnum
int ObjectEnum()
Definition: DoubleInput2.cpp:68
MARSHALLING
#define MARSHALLING(FIELD)
Definition: Marshalling.h:29
Input2
Definition: Input2.h:18
DoubleInput2::GetInput
void GetInput(IssmDouble *pvalue, int index)
Definition: DoubleInput2.cpp:76
printarray
void printarray(IssmPDouble *array, int lines, int cols=1)
Definition: PrintArrays.cpp:6
DoubleInput2::DeepEcho
void DeepEcho()
Definition: DoubleInput2.cpp:42
DoubleInput2::size
int size
Definition: DoubleInput2.h:10
DoubleInput2.h
DoubleInput2::~DoubleInput2
~DoubleInput2()
Definition: DoubleInput2.cpp:28