00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00032 #include "../Include/Database.h"
00033 #include "../Include/Pod.h"
00034 #include "../Include/Endian.h"
00035
00036
00037
00038
00039 CDatabaseField::CDatabaseField (void)
00040 {
00041 type = 0;
00042 length = 0;
00043 memset (data.charData, 0, 256);
00044 }
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072 char CDatabaseField::GetType (void)
00073 {
00074 return type;
00075 }
00076
00077 unsigned long CDatabaseField::GetLength (void)
00078 {
00079 return length;
00080 }
00081
00082 void CDatabaseField::GetString (char *s)
00083 {
00084 if (type == 'C') {
00085
00086 strcpy (s, data.charData);
00087
00088 }
00089 }
00090
00091 double CDatabaseField::GetDouble (void)
00092 {
00093 double rc = 0;
00094 if (type == 'D') {
00095
00096 rc = data.doubleData;
00097
00098 }
00099 return rc;
00100 }
00101
00102 long CDatabaseField::GetInt (void)
00103 {
00104 long rc = 0;
00105 if (type == 'I') {
00106
00107 rc = data.intData;
00108
00109 }
00110 return rc;
00111 }
00112
00113 void CDatabaseField::Format (char *s)
00114 {
00115 switch (type) {
00116 case 'C':
00117 {
00118
00119 strcpy (s, data.charData);
00120
00121
00122 for (unsigned int i=strlen(data.charData); i < length; i++) {
00123 s[i] = ' ';
00124 }
00125
00126
00127 s[length] = '\0';
00128 }
00129 break;
00130
00131 case 'D':
00132 {
00133
00134 sprintf (s, "%g", data.doubleData);
00135 }
00136 break;
00137
00138 case 'I':
00139 {
00140
00141 sprintf (s, "%lu", data.intData);
00142 }
00143 break;
00144 }
00145 }
00146
00147
00148
00149
00150 void ReadULong (PODFILE *f, unsigned long *pData)
00151 {
00152 pread (pData, sizeof(unsigned long), 1, f);
00153 *pData = LittleEndian(*pData);
00154 }
00155
00156
00157
00158
00159
00160 void ReadLong (PODFILE *f, long *pData)
00161 {
00162 pread (pData, sizeof(long), 1, f);
00163 *pData = LittleEndian(*pData);
00164 }
00165
00166
00167
00168
00169
00170
00171 void ReadUShort (PODFILE *f, unsigned short *pData)
00172 {
00173 pread (pData, sizeof(unsigned short), 1, f);
00174 *pData = LittleEndian(*pData);
00175 }
00176
00177
00178
00179
00180
00181
00182 void ReadDouble (PODFILE *f, double *pData)
00183 {
00184 pread (pData, sizeof(double), 1, f);
00185 *pData = LittleEndian(*pData);
00186 }
00187
00188
00189
00190
00191
00192 void ReadFloat (PODFILE *f, float *pData)
00193 {
00194 pread (pData, sizeof(float), 1, f);
00195 *pData = LittleEndian(*pData);
00196 }
00197
00198
00199
00200
00201
00202 void ReadUChar (PODFILE *f, unsigned char *pData)
00203 {
00204 pread (pData, sizeof(unsigned char), 1, f);
00205 }
00206
00207
00208
00209
00210
00211
00212
00213 char * TabNextField (char *s, char *szField)
00214 {
00215 char *pTab = strchr (s, '\t');
00216 if (pTab != NULL) {
00217 int nChars = pTab - s;
00218 strncpy (szField, s, nChars);
00219
00220
00221 s = pTab + 1;
00222 }
00223 return s;
00224 }
00225
00226
00227
00228
00229 char * TabSkipFields (char *s, int nFields)
00230 {
00231 int i;
00232 for (i=0; i<nFields; i++) {
00233 char *pTab = strchr (s, '\t');
00234 if (pTab != NULL) {
00235
00236 s = pTab + 1;
00237 }
00238 }
00239 return s;
00240 }