1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
/******************************************************************************
*
* Project: Shapelib
* Purpose: Sample application for creating a new .dbf file.
* Author: Frank Warmerdam, warmerdam@pobox.com
*
******************************************************************************
* Copyright (c) 1999, Frank Warmerdam
*
* SPDX-License-Identifier: MIT OR LGPL-2.0-or-later
******************************************************************************
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "shapefil.h"
int main(int argc, char **argv)
{
// Display a usage message.
if (argc < 2)
{
printf("dbfcreate xbase_file [[-s field_name width], "
"[-n field_name width decimals]]...\n");
return 1;
}
// Create the database.
DBFHandle hDBF = DBFCreate(argv[1]);
if (hDBF == NULL)
{
printf("DBFCreate(%s) failed.\n", argv[1]);
return 2;
}
// Loop over the field definitions adding new fields.
for (int i = 2; i < argc; i++)
{
if (i < argc - 2 && strcmp(argv[i], "-s") == 0)
{
const char *field = argv[i + 1];
const int width = atoi(argv[i + 2]);
const int decimals = 0;
if (DBFAddField(hDBF, field, FTString, width, decimals) == -1)
{
printf("DBFAddField(%s,FTString,%d,0) failed.\n", field, width);
DBFClose(hDBF);
return 4;
}
i += 2;
}
else if (i < argc - 3 && strcmp(argv[i], "-n") == 0)
{
const char *field = argv[i + 1];
const int width = atoi(argv[i + 2]);
const int decimals = atoi(argv[i + 3]);
if (DBFAddField(hDBF, field, FTDouble, width, decimals) == -1)
{
printf("DBFAddField(%s,FTDouble,%d,%d) failed.\n", field, width,
decimals);
DBFClose(hDBF);
return 4;
}
i += 3;
}
else
{
printf("Argument incomplete, or unrecognised: %s\n", argv[i]);
DBFClose(hDBF);
return 3;
}
}
DBFClose(hDBF);
return 0;
}
|