Ice Sheet System Model  4.18
Code documentation
KML_File.cpp
Go to the documentation of this file.
1 
5 /*Headers:*/
6 /*{{{*/
7 #ifdef HAVE_CONFIG_H
8  #include <config.h>
9 #else
10 #error "Cannot compile with HAVE_CONFIG_H symbol! run configure first!"
11 #endif
12 
13 #include "./KML_File.h"
14 #include "./KML_Object.h"
15 #include "./KMLFileReadUtils.h"
16 #include "../shared/shared.h"
17 /*}}}*/
18 
19 /*Constructors/destructor/copy*/
21 
22  ;
23 
24 }
25 /*}}}*/
27 
28  ;
29 
30 }
31 /*}}}*/
32 
33 /*Other*/
34 void KML_File::Echo(){/*{{{*/
35 
36  bool flag=true;
37 
38  if(flag) _printf0_("KML_File:\n");
40 
41  return;
42 }
43 /*}}}*/
44 void KML_File::DeepEcho(){/*{{{*/
45 
46  char indent[81]="";
47 
48  KML_File::DeepEcho(indent);
49 
50  return;
51 }
52 /*}}}*/
53 void KML_File::DeepEcho(const char* indent){/*{{{*/
54 
55  bool flag=true;
56 
57  if(flag) _printf0_(indent << "KML_File:\n");
58  KML_Object::DeepEcho(indent);
59 
60  return;
61 }
62 /*}}}*/
63 void KML_File::Write(FILE* filout,const char* indent){/*{{{*/
64 
65  fprintf(filout,"%s<kml",indent);
66  WriteAttrib(filout," ");
67  fprintf(filout,">\n");
68  WriteCommnt(filout,indent);
69 
70  KML_Object::Write(filout,indent);
71 
72  fprintf(filout,"%s</kml>\n",indent);
73 
74  return;
75 }
76 /*}}}*/
77 void KML_File::Read(FILE* fid,char* kstr){/*{{{*/
78 
79  char* kstri;
80  int ncom=0;
81  char** pcom=NULL;
82 
83 /* get object attributes and check for solo tag */
84 
85  if (KMLFileTagAttrib(this,
86  kstr))
87  return;
88 
89 /* loop over and process fields within opening and closing tags */
90 
91  while((kstri=KMLFileToken(fid, &ncom,&pcom))){
92  if (!strncmp(kstri,"</kml", 5)) {
93  xDelete<char>(kstri);
94  break;
95  }
96  else if (!strncmp(kstri,"</",2))
97  {_error_("KML_File::Read -- Unexpected closing tag " << kstri << ".");}
98  else if (strncmp(kstri,"<",1))
99  {_error_("KML_File::Read -- Unexpected field \"" << kstri << "\"");}
100 
101  else if (!strncmp(kstri,"<",1))
102  KML_Object::Read(fid,kstri);
103 
104  xDelete<char>(kstri);
105  }
106 
107  this->AddCommnt(ncom,pcom);
108 
109  for(; ncom>0; ncom--) xDelete<char>(pcom[ncom-1]);
110  xDelete<char*>(pcom);
111 
112  return;
113 }
114 /*}}}*/
115 void KML_File::WriteExp(FILE* fid,const char* nstr,int sgn,double cm,double sp){/*{{{*/
116 
117  int i;
118 
119 /* loop over the kml objects for the file */
120 
121  for (i=0; i<kmlobj->Size(); i++)
122  ((KML_Object *)kmlobj->GetObjectByOffset(i))->WriteExp(fid,nstr,sgn,cm,sp);
123 
124  return;
125 }
126 /*}}}*/
DataSet::Size
int Size()
Definition: DataSet.cpp:399
KML_File::WriteExp
void WriteExp(FILE *fid, const char *nstr, int sgn, double cm, double sp)
Definition: KML_File.cpp:115
KML_Object
Definition: KML_Object.h:13
KML_Object.h
: header file for kml_object abstract object
_printf0_
#define _printf0_(StreamArgs)
Definition: Print.h:29
KML_Object::WriteAttrib
virtual void WriteAttrib(FILE *fid, const char *indent)
Definition: KML_Object.cpp:288
KML_File::~KML_File
~KML_File()
Definition: KML_File.cpp:26
KMLFileReadUtils.h
: header file for kml file reading utilities.
KMLFileTagAttrib
int KMLFileTagAttrib(KML_Object *kobj, char *ktag)
Definition: KMLFileReadUtils.cpp:287
KML_File::Write
void Write(FILE *fid, const char *indent)
Definition: KML_File.cpp:63
KML_File::DeepEcho
void DeepEcho()
Definition: KML_File.cpp:44
KML_File::Echo
void Echo()
Definition: KML_File.cpp:34
KML_Object::Read
virtual void Read(FILE *fid, char *kstr)=0
Definition: KML_Object.cpp:143
KML_Object::kmlobj
DataSet * kmlobj
Definition: KML_Object.h:19
KMLFileToken
char * KMLFileToken(FILE *fid, int *pncom=NULL, char ***ppcom=NULL)
Definition: KMLFileReadUtils.cpp:18
KML_File.h
: header file for kml_file object
KML_Object::Write
virtual void Write(FILE *fid, const char *indent)=0
Definition: KML_Object.cpp:122
KML_Object::DeepEcho
virtual void DeepEcho()
Definition: KML_Object.cpp:72
KML_File::Read
void Read(FILE *fid, char *kstr)
Definition: KML_File.cpp:77
_error_
#define _error_(StreamArgs)
Definition: exceptions.h:49
KML_Object::Echo
virtual void Echo()
Definition: KML_Object.cpp:61
DataSet::GetObjectByOffset
Object * GetObjectByOffset(int offset)
Definition: DataSet.cpp:334
KML_File::KML_File
KML_File()
Definition: KML_File.cpp:20
KML_Object::AddCommnt
virtual void AddCommnt(int ncom, char **pcom)
Definition: KML_Object.cpp:301
KML_Object::WriteCommnt
virtual void WriteCommnt(FILE *fid, const char *indent)
Definition: KML_Object.cpp:326