/* MDB Tools - A library for reading MS Access database file * Copyright (C) 2000 Brian Bruns * * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ #include "mdbtools.h" #define MAX_ROW_SIZE 4096 void free_values(MdbField *fields, int num_fields) { int i; for (i=0;icolnum = col->col_num; field->is_fixed = col->is_fixed; switch (col->col_type) { case MDB_TEXT: field->value = g_strdup(s); field->siz = strlen(s); break; case MDB_BYTE: any.i = strtol(s, &c, 16); if (*c) return 1; field->siz = mdb_col_fixed_size(col); field->value = g_malloc(field->siz); ((unsigned char *)field->value)[0] = any.i; break; case MDB_INT: any.i = strtol(s, &c, 16); if (*c) return 1; field->siz = mdb_col_fixed_size(col); field->value = g_malloc(field->siz); _mdb_put_int16(field->value, 0, any.i); break; case MDB_LONGINT: any.i = strtol(s, &c, 16); if (*c) return 1; field->siz = mdb_col_fixed_size(col); field->value = g_malloc(field->siz); _mdb_put_int32(field->value, 0, any.i); break; case MDB_BOOL: if (*s == '1') { field->is_null = 1; } else if (*s == '0') { field->is_null = 0; } else { fprintf(stderr, "%c is not a valid value for type BOOLEAN\n", *s); return 1; } /* case MDB_FLOAT: any.d = strtod(s, &c); if (*c) return 1; field.value = g_malloc(mdb_col_fixed_size(col)); _mdb_put_single(field.value, 0, any.i); break; case MDB_DOUBLE: any.d = strtod(s, &c); if (*c) return 1; field.value = g_malloc(mdb_col_fixed_size(col)); _mdb_put_double(field.value, 0, any.i); break; */ /* case MDB_MONEY: case MDB_SDATETIME: case MDB_OLE: case MDB_MEMO: case MDB_REPID: case MDB_NUMERIC: */ default: fprintf(stderr,"Conversion of type %02x not supported yet.\n", col->col_type); return 1; break; } return 0; } int prep_row(MdbTableDef *table, char *line, MdbField *fields, char *delim) { MdbColumn *col; char **sarray, *s; unsigned int i; /* * pull apart the row and turn it into something respectable */ g_strdelimit(line, delim, '\n'); sarray = g_strsplit (line, "\n", 0); for (i=0; (s = sarray[i]); i++) { if (!strlen(s)) continue; if (i >= table->num_cols) { fprintf(stderr, "Number of columns in file exceeds number in table.\n"); g_strfreev(sarray); return 0; } if (s[0]=='"' && s[strlen(s)-1]=='"') { s[strlen(s)-1] = '\0'; memmove(s+1, s, strlen(s)); } printf("field = %s\n", s); col = g_ptr_array_index (table->columns, i); if (convert_field(col, s, &fields[i])) { fprintf(stderr, "Format error in column %d\n", i+1); g_strfreev(sarray); return 0; } } g_strfreev(sarray); /* * verify number of columns in table against number in row */ if (i < table->num_cols) { fprintf(stderr, "Row has %d columns, but table has %d\n", i, table->num_cols); free_values(fields, i); return 0; } return i-1; } int main(int argc, char **argv) { int i, row; MdbHandle *mdb; MdbTableDef *table; MdbField fields[256]; char line[MAX_ROW_SIZE]; int num_fields; /* doesn't handle tables > 256 columns. Can that happen? */ int opt; FILE *in; char delimiter[2] = ","; char header_rows = 0; while ((opt=getopt(argc, argv, "H:d:"))!=-1) { switch (opt) { case 'H': header_rows = atol(optarg); break; case 'd': delimiter[0] = optarg[0]; break; default: break; } } /* ** optind is now the position of the first non-option arg, ** see getopt(3) */ if (argc-optind < 3) { fprintf(stderr,"Usage: %s [options] \n",argv[0]); fprintf(stderr,"where options are:\n"); fprintf(stderr," -H skip header rows\n"); fprintf(stderr," -d specify a column delimiter\n"); exit(1); } mdb_init(); if (!(mdb = mdb_open(argv[optind], MDB_WRITABLE))) { exit(1); } table = mdb_read_table_by_name(mdb, argv[argc-2], MDB_TABLE); if (!table) { fprintf(stderr,"Table %s not found in database\n", argv[argc-2]); exit(1); } mdb_read_columns(table); mdb_read_indices(table); mdb_rewind_table(table); /* * open the CSV file and read any header rows */ in = fopen(argv[argc-1], "r"); if (!in) { fprintf(stderr, "Can not open file %s\n", argv[argc-1]); exit(1); } for (i=0;i