81{
84 char *header, *footer, *record;
85 int c;
86 int ret, i;
87
88#ifdef ENABLE_NLS
89#ifdef PGSQL_LOCALEDIR
90 setlocale (LC_ALL, "");
91 bindtextdomain (PACKAGE, PGSQL_LOCALEDIR);
92 textdomain (PACKAGE);
93#endif
94#endif
95
96
97 if (argc == 1)
98 {
100 exit(0);
101 }
102
103
106
107
108 while ((c =
pgis_getopt(argc, argv,
"-?acdeg:ikm:nps:t:wDGIN:ST:W:X:Z")) != EOF)
109 {
110
111 if ('-' == c)
112 break;
113
114 switch (c)
115 {
116 case 'c':
117 case 'd':
118 case 'a':
119 case 'p':
121 break;
122
123 case 'D':
125 break;
126
127 case 'G':
129 break;
130
131 case 'Z':
133 break;
134
135 case 'S':
137 break;
138
139 case 's':
141 {
143 if (ptr)
144 {
145 *ptr++ = '\0';
147 sscanf(ptr,
"%d", &config->
sr_id);
148 }
149 else
150 {
151
153 }
154 }
155 else
156 {
157
158 fprintf(stderr, "The -s parameter must be specified in the form [FROM_SRID:]TO_SRID\n");
159 exit(1);
160 }
161 break;
162 case 'g':
164 break;
165 case 'm':
167 break;
168
169 case 'k':
171 break;
172
173 case 'i':
175 break;
176
177 case 'I':
179 break;
180
181 case 'w':
183 break;
184
185 case 'n':
187 break;
188
189 case 'W':
192 break;
193
194 case 'N':
196 {
197 case 'a':
199 break;
200 case 'i':
202 break;
203 case 's':
205 break;
206 default:
207 fprintf(stderr, "Unsupported NULL geometry handling policy.\nValid policies: insert, skip, abort\n");
208 exit(1);
209 }
210 break;
211
212 case 't':
214 {
216 }
218 {
220 }
222 {
224 }
226 {
228 }
229 else
230 {
231 fprintf(stderr,
"Unsupported output type: %s\nValid output types are 2D, 3DZ, 3DM and 4D\n",
pgis_optarg);
232 exit(1);
233 }
234 break;
235
236 case 'T':
238 break;
239
240 case 'X':
242 break;
243
244 case 'e':
246 break;
247
248 case '?':
250 exit(0);
251
252 default:
254 exit(0);
255 }
256 }
257
258
260 {
261 fprintf(stderr, "Invalid argument combination - cannot use both -D and -e\n");
262 exit(1);
263 }
264
265
267 {
270 }
271 else
272 {
274 exit(0);
275 }
276
277
279 {
281 char *chrptr = strchr(strptr, '.');
282
283
284 if (chrptr)
285 {
286 if ( chrptr == strptr )
287 {
288
290 exit(0);
291 }
292
293 *chrptr = '\0';
294
295 config->
schema = strdup(strptr);
296 config->
table = strdup(chrptr+1);
297 }
298 else
299 {
300 config->
table = strdup(strptr);
301 }
302 }
303
304
305
307 {
308 char *shp_file = strdup(config->
shp_file);
309 char *ptr;
310
311 if ( shp_file == NULL )
312 {
313 fprintf(stderr, "Unable to allocate memory for shapefile name\n");
314 exit(1);
315 }
316
317
318 for ( ptr = shp_file + strlen(shp_file); ptr > shp_file; ptr-- )
319 {
320 if ( *ptr == '.' )
321 {
322 *ptr = '\0';
323 break;
324 }
325 }
326
327
328 for ( ptr = shp_file + strlen(shp_file); ptr > shp_file; ptr-- )
329 {
330 if ( *ptr == '/' || *ptr == '\\' )
331 {
332 ptr++;
333 break;
334 }
335 }
336 config->
table = strdup(ptr);
338 }
339
340
341
343 {
348 }
349
350
352
353
356 {
357 fprintf(stderr,
"%s\n", state->
message);
358
360 exit(1);
361 }
362
363
365 {
367 fprintf(stderr,
"Postgis type: %s[%d]\n", state->
pgtype, state->
pgdims);
368 }
369
370
373 {
374 fprintf(stderr,
"%s\n", state->
message);
375
377 exit(1);
378 }
379
380 printf("%s", header);
382
383
385 {
386
387
389 {
392 {
393 fprintf(stderr,
"%s\n", state->
message);
394
396 exit(1);
397 }
398
399 printf("%s", header);
401 }
402
403
405 {
407
408 switch (ret)
409 {
411
412 printf("%s\n", record);
414 break;
415
417
418 fprintf(stderr,
"%s\n", state->
message);
419 exit(1);
420 break;
421
423
424 fprintf(stderr,
"%s\n", state->
message);
425 printf("%s\n", record);
427 break;
428
430
431 break;
432
434
435 break;
436 }
437 }
438
439
441 printf("\\.\n");
442
443 }
444
445
448 {
449 fprintf(stderr,
"%s\n", state->
message);
450
452 exit(1);
453 }
454
455 printf("%s", footer);
457
458
459
461
462
467
468 return 0;
469}
int pgis_getopt(int argc, char **argv, char *opts)
const char SHPAPI_CALL1 * SHPTypeName(int nSHPType);const char SHPAPI_CALL1(*) SHPPartTypeName(int nPartType
int ShpLoaderGetRecordCount(SHPLOADERSTATE *state)
void ShpLoaderDestroy(SHPLOADERSTATE *state)
SHPLOADERSTATE * ShpLoaderCreate(SHPLOADERCONFIG *config)
int ShpLoaderGetSQLCopyStatement(SHPLOADERSTATE *state, char **strheader)
int ShpLoaderOpenShape(SHPLOADERSTATE *state)
int ShpLoaderGenerateSQLRowStatement(SHPLOADERSTATE *state, int item, char **strrecord)
void set_loader_config_defaults(SHPLOADERCONFIG *config)
int ShpLoaderGetSQLFooter(SHPLOADERSTATE *state, char **strfooter)
int ShpLoaderGetSQLHeader(SHPLOADERSTATE *state, char **strheader)
#define POLICY_NULL_ABORT
#define SHPLOADERRECISNULL
#define POLICY_NULL_INSERT
#define SHPLOADERRECDELETED
char * column_map_filename
char message[SHPLOADERMSGLEN]