IPP Software Navigation Tools IPP Links Communication Pan-STARRS Links

Ticket #666: psMetadataConfigFormat.c

File psMetadataConfigFormat.c, 6.2 KB (added by eugene, 20 years ago)

cleanup of psMetadataConfigFormat

Line 
1psString psMetadataConfigFormat(psMetadata *md)
2{
3 PS_ASSERT_PTR_NON_NULL(md, NULL);
4
5 psString mdString = NULL;
6 psString content = NULL;
7
8 psMetadataItem *item = NULL;
9 psMetadataIterator *iter = psMetadataIteratorAlloc(md, PS_LIST_HEAD, NULL);
10
11 while ( (item = psMetadataGetAndIncrement(iter)) ) {
12 if (item == NULL) {
13 // XXX : this is probably not the right error value
14 psError(PS_ERR_BAD_PARAMETER_VALUE, true, PS_ERRORTEXT_psMetadata_METATYPE_INVALID, PS_DATA_UNKNOWN);
15 psFree(iter);
16 return NULL;
17 }
18
19 // In this block, the single item is used to build 'content'
20 switch (item->type) {
21 case PS_DATA_BOOL:
22 psStringAppend (&content, "%s BOOL ", item->name);
23 if ( item->data.B ) {
24 psStringAppend(&content, "TRUE");
25 } else {
26 psStringAppend(&content, "FALSE");
27 }
28 if ( item->comment != NULL ) {
29 psStringAppend(&content, " #%s", item->comment);
30 }
31 psStringAppend(&content, " \n", item->comment);
32 break;
33 case PS_DATA_S32:
34 psStringAppend(&content, "%s S32 ", item->name);
35 psStringAppend(&content, "%d ", item->data.S32);
36 if ( strncmp(item->comment,"",2) ) {
37 psStringAppend(&content, " #%s", item->comment);
38 }
39 psStringAppend(&content, " \n");
40 break;
41 case PS_DATA_F32:
42 psStringAppend(&content, "%s F32 ", item->name);
43 psStringAppend(&content, "%22.15g ", item->data.F32);
44 if ( strncmp(item->comment,"",2) ) {
45 psStringAppend(&content, " #%s", item->comment);
46 }
47 psStringAppend(&content, " \n");
48 break;
49 case PS_DATA_F64:
50 psStringAppend(&content, "%s F64 ", item->name);
51 psStringAppend(&content, "%22.15g ", item->data.F64);
52 if ( strncmp(item->comment,"",2) ) {
53 psStringAppend(&content, " #%s", item->comment);
54 }
55 psStringAppend(&content, " \n");
56 break;
57 case PS_DATA_STRING:
58 psStringAppend(&content, "%s STR ", item->name);
59 psStringAppend(&content, "%s ", ((char *)(item->data.V)));
60 if ( strncmp(item->comment,"",2) ) {
61 psStringAppend(&content, " #%s", item->comment);
62 }
63 psStringAppend(&content, " \n");
64 break;
65 case PS_DATA_METADATA:
66 psStringAppend(&content, "\n%s METADATA ", item->name);
67 psString newStr = psMetadataConfigFormat(item->data.md);
68 // XXX need to check for NULL return value, implying error
69 // from a lower level
70
71 // add 3 extra spaces to each metadata folder item
72 char *buffer2 = strtok(newStr, "\n");
73 while( buffer2 != NULL ) {
74 psStringAppend(&content, "\n %s", buffer2);
75 buffer2 = strtok(NULL, "\n");
76 }
77 if ( strncmp(item->comment,"",2) ) {
78 psStringAppend(&content, "\nEND #%s\n\n", item->comment);
79 } else {
80 psStringAppend(&content, "\nEND\n\n");
81 }
82 psFree(newStr);
83 break;
84 case PS_DATA_TIME:
85 psStringAppend(&content, "%s ", item->name);
86 psTime *time = item->data.V;
87 if ( time->type == PS_TIME_UTC )
88 psStringAppend(&content, "PS_TIME_UTC ");
89 else if ( time->type == PS_TIME_TAI )
90 psStringAppend(&content, "PS_TIME_TAI ");
91 else if ( time->type == PS_TIME_UT1 )
92 psStringAppend(&content, "PS_TIME_UT1 ");
93 else if ( time->type == PS_TIME_TT )
94 psStringAppend(&content, "PS_TIME_TT ");
95 else {
96 psError(PS_ERR_BAD_PARAMETER_VALUE, true, PS_ERRORTEXT_psMetadata_METATYPE_INVALID, time->type);
97 // XXX memory leak: should free content and mdString before returning
98 psFree(iter);
99 return NULL;
100 }
101
102 psStringAppend(&content, "%ld, ", (long)time->sec);
103 psStringAppend(&content, "%u, ", time->nsec);
104 if ( time->leapsecond )
105 psStringAppend(&content, "T ");
106 else
107 psStringAppend(&content, "F ");
108 if ( strncmp(item->comment,"",2) ) {
109 psStringAppend(&content, " #%s", item->comment);
110 }
111 psStringAppend(&content, " \n");
112 break;
113 case PS_DATA_VECTOR:
114 psStringAppend(&content, "@%s ", item->name);
115 psVector *vector = item->data.V;
116
117 switch (vector->type.type) {
118 case PS_DATA_S32:
119 psStringAppend(&content, "S32 ");
120 for (int i = 0; i < vector->n; i++) {
121 psStringAppend(&content, "%d ", vector->data.S32[i]);
122 }
123 break;
124 case PS_DATA_F32:
125 psStringAppend(&content, "F32 ", MAXSTR);
126 for (int i = 0; i < vector->n; i++) {
127 psStringAppend(&content, "%f ", vector->data.F32[i]);
128 }
129 break;
130 case PS_DATA_F64:
131 psStringAppend(&content, "F64 ", MAXSTR);
132 for (int i = 0; i < vector->n; i++) {
133 psStringAppend(&content, "%lf", vector->data.F64[i]);
134 }
135 break;
136 case PS_DATA_UNKNOWN:
137 default:
138 psError(PS_ERR_BAD_PARAMETER_VALUE, true,
139 PS_ERRORTEXT_psMetadata_METATYPE_INVALID, vector->type.type);
140 psFree(iter);
141 // XXX memory leak: should free content and mdString before returning
142 return NULL;
143 }
144 if ( strncmp(item->comment,"",2) ) {
145 psStringAppend(&content, " #%s", item->comment);
146 }
147 psStringAppend(&content, " \n");
148 break;
149 case PS_DATA_UNKNOWN:
150 default:
151 psError(PS_ERR_BAD_PARAMETER_VALUE, true,
152 PS_ERRORTEXT_psMetadata_METATYPE_INVALID, item->type);
153 psFree(iter);
154 // XXX memory leak: should free content and mdString before returning
155 return NULL;
156 }
157 psStringAppend(&mdString, content);
158 psFree(content);
159 content = NULL;
160 }
161 psFree(iter);
162 return mdString;
163}
164