mirror of
https://github.com/mdbtools/mdbtools.git
synced 2025-06-28 15:39:02 +08:00
jet 4 changes
This commit is contained in:
parent
acc20193c5
commit
0cf1a2242d
@ -21,6 +21,7 @@
|
|||||||
#define _mdbtools_h_
|
#define _mdbtools_h_
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
@ -29,13 +30,15 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
|
|
||||||
|
#define MDB_DEBUG 0
|
||||||
|
|
||||||
#define MDB_PGSIZE 4096
|
#define MDB_PGSIZE 4096
|
||||||
#define MDB_MAX_OBJ_NAME 30
|
#define MDB_MAX_OBJ_NAME 30
|
||||||
#define MDB_MAX_COLS 256
|
#define MDB_MAX_COLS 256
|
||||||
#define MDB_MAX_IDX_COLS 10
|
#define MDB_MAX_IDX_COLS 10
|
||||||
#define MDB_CATALOG_PG 18
|
#define MDB_CATALOG_PG 18
|
||||||
#define MDB_MEMO_OVERHEAD 12
|
#define MDB_MEMO_OVERHEAD 12
|
||||||
#define MDB_BIND_SIZE 4096
|
#define MDB_BIND_SIZE 65536
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
MDB_VER_JET3 = 0,
|
MDB_VER_JET3 = 0,
|
||||||
@ -67,7 +70,8 @@ enum {
|
|||||||
MDB_TEXT = 0x0a,
|
MDB_TEXT = 0x0a,
|
||||||
MDB_OLE = 0x0b,
|
MDB_OLE = 0x0b,
|
||||||
MDB_MEMO = 0x0c,
|
MDB_MEMO = 0x0c,
|
||||||
MDB_REPID = 0x0f
|
MDB_REPID = 0x0f,
|
||||||
|
MDB_NUMERIC = 0x10
|
||||||
};
|
};
|
||||||
|
|
||||||
/* SARG operators */
|
/* SARG operators */
|
||||||
@ -188,6 +192,9 @@ typedef struct {
|
|||||||
int col_num;
|
int col_num;
|
||||||
int cur_value_start;
|
int cur_value_start;
|
||||||
int cur_value_len;
|
int cur_value_len;
|
||||||
|
/* numerics only */
|
||||||
|
int col_prec;
|
||||||
|
int col_scale;
|
||||||
} MdbColumn;
|
} MdbColumn;
|
||||||
|
|
||||||
typedef union {
|
typedef union {
|
||||||
@ -214,10 +221,12 @@ extern size_t mdb_read_pg(MdbHandle *mdb, unsigned long pg);
|
|||||||
extern size_t mdb_read_alt_pg(MdbHandle *mdb, unsigned long pg);
|
extern size_t mdb_read_alt_pg(MdbHandle *mdb, unsigned long pg);
|
||||||
extern unsigned char mdb_get_byte(MdbHandle *mdb, int offset);
|
extern unsigned char mdb_get_byte(MdbHandle *mdb, int offset);
|
||||||
extern int mdb_get_int16(MdbHandle *mdb, int offset);
|
extern int mdb_get_int16(MdbHandle *mdb, int offset);
|
||||||
|
extern gint32 mdb_get_int24(MdbHandle *mdb, int offset);
|
||||||
extern long mdb_get_int32(MdbHandle *mdb, int offset);
|
extern long mdb_get_int32(MdbHandle *mdb, int offset);
|
||||||
extern float mdb_get_single(MdbHandle *mdb, int offset);
|
extern float mdb_get_single(MdbHandle *mdb, int offset);
|
||||||
extern double mdb_get_double(MdbHandle *mdb, int offset);
|
extern double mdb_get_double(MdbHandle *mdb, int offset);
|
||||||
extern MdbHandle *mdb_open(char *filename);
|
extern MdbHandle *mdb_open(char *filename);
|
||||||
|
extern void mdb_swap_pgbuf(MdbHandle *mdb);
|
||||||
|
|
||||||
/* catalog.c */
|
/* catalog.c */
|
||||||
extern void mdb_catalog_dump(MdbHandle *mdb, int obj_type);
|
extern void mdb_catalog_dump(MdbHandle *mdb, int obj_type);
|
||||||
@ -247,4 +256,6 @@ extern void mdb_register_backend(MdbBackend *backend, char *backend_name);
|
|||||||
extern int mdb_set_default_backend(MdbHandle *mdb, char *backend_name);
|
extern int mdb_set_default_backend(MdbHandle *mdb, char *backend_name);
|
||||||
extern char *mdb_get_relationships(MdbHandle *mdb);
|
extern char *mdb_get_relationships(MdbHandle *mdb);
|
||||||
|
|
||||||
|
/* sargs.c */
|
||||||
|
int mdb_test_sargs(MdbHandle *mdb, MdbColumn *col, int offset, int len);
|
||||||
#endif /* _mdbtools_h_ */
|
#endif /* _mdbtools_h_ */
|
||||||
|
@ -40,7 +40,8 @@ char *mdb_access_types[] =
|
|||||||
"Memo/Hyperlink",
|
"Memo/Hyperlink",
|
||||||
"Unknown 0x0d",
|
"Unknown 0x0d",
|
||||||
"Unknown 0x0e",
|
"Unknown 0x0e",
|
||||||
"Replication ID"};
|
"Replication ID",
|
||||||
|
"Numeric"};
|
||||||
|
|
||||||
/* Oracle data types */
|
/* Oracle data types */
|
||||||
char *mdb_oracle_types[] =
|
char *mdb_oracle_types[] =
|
||||||
@ -59,6 +60,7 @@ char *mdb_oracle_types[] =
|
|||||||
"CLOB",
|
"CLOB",
|
||||||
"Oracle_Unknown 0x0d",
|
"Oracle_Unknown 0x0d",
|
||||||
"Oracle_Unknown 0x0e",
|
"Oracle_Unknown 0x0e",
|
||||||
|
"NUMBER",
|
||||||
"NUMBER"};
|
"NUMBER"};
|
||||||
|
|
||||||
/* Sybase/MSSQL data types */
|
/* Sybase/MSSQL data types */
|
||||||
@ -78,7 +80,8 @@ char *mdb_sybase_types[] =
|
|||||||
"text",
|
"text",
|
||||||
"Sybase_Unknown 0x0d",
|
"Sybase_Unknown 0x0d",
|
||||||
"Sybase_Unknown 0x0e",
|
"Sybase_Unknown 0x0e",
|
||||||
"Sybase_Replication ID"};
|
"Sybase_Replication ID",
|
||||||
|
"numeric"};
|
||||||
|
|
||||||
/* Postgres data types */
|
/* Postgres data types */
|
||||||
char *mdb_postgres_types[] =
|
char *mdb_postgres_types[] =
|
||||||
@ -97,7 +100,8 @@ char *mdb_postgres_types[] =
|
|||||||
"Postgres_Unknown 0x0c",
|
"Postgres_Unknown 0x0c",
|
||||||
"Postgres_Unknown 0x0d",
|
"Postgres_Unknown 0x0d",
|
||||||
"Postgres_Unknown 0x0e",
|
"Postgres_Unknown 0x0e",
|
||||||
"Serial"};
|
"Serial",
|
||||||
|
"Postgres_Unknown 0x10"};
|
||||||
|
|
||||||
char *bound_values[MDB_MAX_COLS];
|
char *bound_values[MDB_MAX_COLS];
|
||||||
char *relationships[4];
|
char *relationships[4];
|
||||||
@ -108,8 +112,11 @@ int did_first;
|
|||||||
|
|
||||||
char *mdb_get_coltype_string(MdbBackend *backend, int col_type)
|
char *mdb_get_coltype_string(MdbBackend *backend, int col_type)
|
||||||
{
|
{
|
||||||
if (col_type > 0x0f) {
|
char buf[100];
|
||||||
return NULL;
|
if (col_type > 0x10) {
|
||||||
|
// return NULL;
|
||||||
|
sprintf(buf,"type %04x", col_type);
|
||||||
|
return buf;
|
||||||
} else {
|
} else {
|
||||||
return backend->types_table[col_type];
|
return backend->types_table[col_type];
|
||||||
}
|
}
|
||||||
|
@ -18,12 +18,14 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "mdbtools.h"
|
#include "mdbtools.h"
|
||||||
|
#include "time.h"
|
||||||
|
#include "math.h"
|
||||||
|
|
||||||
char *mdb_money_to_string(MdbHandle *mdb, int start, char *s);
|
char *mdb_money_to_string(MdbHandle *mdb, int start, char *s);
|
||||||
static int _mdb_attempt_bind(MdbHandle *mdb,
|
static int _mdb_attempt_bind(MdbHandle *mdb,
|
||||||
MdbColumn *col, unsigned char isnull, int offset, int len);
|
MdbColumn *col, unsigned char isnull, int offset, int len);
|
||||||
|
char *mdb_num_to_string(MdbHandle *mdb, int start, int datatype, int prec, int scale);
|
||||||
|
|
||||||
#define MDB_DEBUG 0
|
|
||||||
|
|
||||||
void mdb_bind_column(MdbTableDef *table, int col_num, void *bind_ptr)
|
void mdb_bind_column(MdbTableDef *table, int col_num, void *bind_ptr)
|
||||||
{
|
{
|
||||||
@ -44,7 +46,7 @@ MdbColumn *col;
|
|||||||
}
|
}
|
||||||
int mdb_find_end_of_row(MdbHandle *mdb, int row)
|
int mdb_find_end_of_row(MdbHandle *mdb, int row)
|
||||||
{
|
{
|
||||||
int row_start, row_end, i;
|
int row_end;
|
||||||
|
|
||||||
/* Search the previous "row start" values for the first non-deleted one.
|
/* Search the previous "row start" values for the first non-deleted one.
|
||||||
* If we don't find one, then the end of the page is the correct value.
|
* If we don't find one, then the end of the page is the correct value.
|
||||||
@ -92,6 +94,8 @@ static int mdb_xfer_bound_bool(MdbHandle *mdb, MdbColumn *col, int value)
|
|||||||
if (col->bind_ptr) {
|
if (col->bind_ptr) {
|
||||||
strcpy(col->bind_ptr, value ? "0" : "1");
|
strcpy(col->bind_ptr, value ? "0" : "1");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
static int mdb_xfer_bound_data(MdbHandle *mdb, int start, MdbColumn *col, int len)
|
static int mdb_xfer_bound_data(MdbHandle *mdb, int start, MdbColumn *col, int len)
|
||||||
{
|
{
|
||||||
@ -108,8 +112,14 @@ int ret;
|
|||||||
}
|
}
|
||||||
if (col->bind_ptr) {
|
if (col->bind_ptr) {
|
||||||
if (len) {
|
if (len) {
|
||||||
strcpy(col->bind_ptr,
|
//fprintf(stdout,"len %d size %d\n",len, col->col_size);
|
||||||
|
if (col->col_type == MDB_NUMERIC) {
|
||||||
|
strcpy(col->bind_ptr,
|
||||||
|
mdb_num_to_string(mdb, start, col->col_type, col->col_prec, col->col_scale));
|
||||||
|
} else {
|
||||||
|
strcpy(col->bind_ptr,
|
||||||
mdb_col_to_string(mdb, start, col->col_type, len));
|
mdb_col_to_string(mdb, start, col->col_type, len));
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
strcpy(col->bind_ptr, "");
|
strcpy(col->bind_ptr, "");
|
||||||
}
|
}
|
||||||
@ -129,7 +139,7 @@ int i, j, rc;
|
|||||||
int num_cols, var_cols, fixed_cols;
|
int num_cols, var_cols, fixed_cols;
|
||||||
int row_start, row_end;
|
int row_start, row_end;
|
||||||
int fixed_cols_found, var_cols_found;
|
int fixed_cols_found, var_cols_found;
|
||||||
int col_start, len;
|
int col_start, len, next_col;
|
||||||
int num_of_jumps=0, jumps_used=0;
|
int num_of_jumps=0, jumps_used=0;
|
||||||
int eod; /* end of data */
|
int eod; /* end of data */
|
||||||
int delflag, lookupflag;
|
int delflag, lookupflag;
|
||||||
@ -271,8 +281,24 @@ unsigned char isnull;
|
|||||||
len=eod - col_start;
|
len=eod - col_start;
|
||||||
} else {
|
} else {
|
||||||
if (mdb->jet_version==MDB_VER_JET4) {
|
if (mdb->jet_version==MDB_VER_JET4) {
|
||||||
len=mdb->pg_buf[row_end - bitmask_sz - var_cols_found * 2
|
//next_col = mdb_get_int16(mdb, row_end - bitmask_sz - var_cols_found * 2 - 2 - 1) ;
|
||||||
- 2 - 1 - num_of_jumps * 2] - col_start;
|
next_col = mdb->pg_buf[row_end - bitmask_sz - var_cols_found * 2 - 2] * 256 +
|
||||||
|
mdb->pg_buf[row_end - bitmask_sz - var_cols_found * 2 - 2 - 1] ;
|
||||||
|
len = next_col - col_start;
|
||||||
|
/* len=mdb->pg_buf[row_end - bitmask_sz - var_cols_found * 2
|
||||||
|
- 2 - 1] - col_start; */
|
||||||
|
//len=mdb->pg_buf[row_end - bitmask_sz - var_cols_found * 2
|
||||||
|
//- 2 - 1 - num_of_jumps * 2] - col_start;
|
||||||
|
/*
|
||||||
|
fprintf(stdout, "found %d fix %d new pos %d new start %d old start %d\n",
|
||||||
|
var_cols_found,
|
||||||
|
row_end - bitmask_sz - var_cols_found * 2
|
||||||
|
- 2 - 1,
|
||||||
|
row_end - bitmask_sz - var_cols_found * 2
|
||||||
|
- 2 - 1 - num_of_jumps * 2,
|
||||||
|
mdb->pg_buf[row_end - bitmask_sz - var_cols_found * 2
|
||||||
|
- 2 - 1], col_start);
|
||||||
|
*/
|
||||||
} else {
|
} else {
|
||||||
len=mdb->pg_buf[col_ptr - var_cols_found ] - col_start;
|
len=mdb->pg_buf[col_ptr - var_cols_found ] - col_start;
|
||||||
}
|
}
|
||||||
@ -328,6 +354,8 @@ int mdb_rewind_table(MdbTableDef *table)
|
|||||||
table->cur_pg_num=0;
|
table->cur_pg_num=0;
|
||||||
table->cur_phys_pg=0;
|
table->cur_phys_pg=0;
|
||||||
table->cur_row=0;
|
table->cur_row=0;
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
int mdb_fetch_row(MdbTableDef *table)
|
int mdb_fetch_row(MdbTableDef *table)
|
||||||
{
|
{
|
||||||
@ -399,21 +427,26 @@ guint16 row_start, row_stop;
|
|||||||
guint8 memo_row;
|
guint8 memo_row;
|
||||||
guint32 lval_pg;
|
guint32 lval_pg;
|
||||||
guint16 len;
|
guint16 len;
|
||||||
|
int i;
|
||||||
|
|
||||||
if (size<MDB_MEMO_OVERHEAD) {
|
if (size<MDB_MEMO_OVERHEAD) {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if MDB_DEBUG
|
||||||
|
buffer_dump(mdb->pg_buf, start, start + 12);
|
||||||
|
#endif
|
||||||
|
|
||||||
memo_len = mdb_get_int16(mdb, start);
|
memo_len = mdb_get_int16(mdb, start);
|
||||||
memo_flags = mdb_get_int16(mdb, start+2);
|
memo_flags = mdb_get_int16(mdb, start+2);
|
||||||
|
|
||||||
if (memo_flags == 0x8000) {
|
if (memo_flags & 0x8000) {
|
||||||
/* inline memo field */
|
/* inline memo field */
|
||||||
strncpy(text, &mdb->pg_buf[start + MDB_MEMO_OVERHEAD],
|
strncpy(text, &mdb->pg_buf[start + MDB_MEMO_OVERHEAD],
|
||||||
size - MDB_MEMO_OVERHEAD);
|
size - MDB_MEMO_OVERHEAD);
|
||||||
text[size - MDB_MEMO_OVERHEAD]='\0';
|
text[size - MDB_MEMO_OVERHEAD]='\0';
|
||||||
return text;
|
return text;
|
||||||
} else if (memo_flags == 0x4000) {
|
} else if (memo_flags & 0x4000) {
|
||||||
/* The 16 bit integer at offset 0 is the length of the memo field.
|
/* The 16 bit integer at offset 0 is the length of the memo field.
|
||||||
* The 24 bit integer at offset 5 is the page it is stored on.
|
* The 24 bit integer at offset 5 is the page it is stored on.
|
||||||
*/
|
*/
|
||||||
@ -430,21 +463,35 @@ guint16 len;
|
|||||||
/* swap the alt and regular page buffers, so we can call get_int16 */
|
/* swap the alt and regular page buffers, so we can call get_int16 */
|
||||||
mdb_swap_pgbuf(mdb);
|
mdb_swap_pgbuf(mdb);
|
||||||
if (memo_row) {
|
if (memo_row) {
|
||||||
row_stop = mdb_get_int16(mdb, 10 + (memo_row - 1) * 2) & 0x0FFF;
|
row_stop = mdb_get_int16(mdb, mdb->row_count_offset + 2 + (memo_row - 1) * 2) & 0x0FFF;
|
||||||
} else {
|
} else {
|
||||||
row_stop = mdb->pg_size - 1;
|
row_stop = mdb->pg_size - 1;
|
||||||
}
|
}
|
||||||
row_start = mdb_get_int16(mdb, 10 + memo_row * 2);
|
row_start = mdb_get_int16(mdb, mdb->row_count_offset + 2 + memo_row * 2);
|
||||||
#if MDB_DEBUG
|
#if MDB_DEBUG
|
||||||
printf("row num %d row start %d row stop %d\n", memo_row, row_start, row_stop);
|
printf("row num %d row start %d row stop %d\n", memo_row, row_start, row_stop);
|
||||||
|
buffer_dump(mdb->pg_buf,row_start, row_start + len);
|
||||||
#endif
|
#endif
|
||||||
len = row_stop - row_start;
|
len = row_stop - row_start;
|
||||||
strncpy(text, &mdb->pg_buf[row_start], len);
|
if (mdb->jet_version==MDB_VER_JET3) {
|
||||||
text[len]='\0';
|
strncpy(text, &mdb->pg_buf[row_start], len);
|
||||||
|
text[len]='\0';
|
||||||
|
} else {
|
||||||
|
if (mdb->pg_buf[row_start]==0xff &&
|
||||||
|
mdb->pg_buf[row_start+1]==0xfe) {
|
||||||
|
strncpy(text, &mdb->pg_buf[row_start+2], len-2);
|
||||||
|
text[len-2]='\0';
|
||||||
|
} else {
|
||||||
|
/* convert unicode to ascii, rather sloppily */
|
||||||
|
for (i=0;i<len;i+=2)
|
||||||
|
text[i/2] = mdb->pg_buf[row_start + i];
|
||||||
|
text[len/2]='\0';
|
||||||
|
}
|
||||||
|
}
|
||||||
/* make sure to swap page back */
|
/* make sure to swap page back */
|
||||||
mdb_swap_pgbuf(mdb);
|
mdb_swap_pgbuf(mdb);
|
||||||
return text;
|
return text;
|
||||||
} else if (memo_flags == 0x0000) {
|
} else { /* if (memo_flags == 0x0000) { */
|
||||||
memo_row = mdb->pg_buf[start+4];
|
memo_row = mdb->pg_buf[start+4];
|
||||||
lval_pg = mdb_get_int24(mdb, start+5);
|
lval_pg = mdb_get_int24(mdb, start+5);
|
||||||
#if MDB_DEBUG
|
#if MDB_DEBUG
|
||||||
@ -480,9 +527,11 @@ guint16 len;
|
|||||||
/* make sure to swap page back */
|
/* make sure to swap page back */
|
||||||
mdb_swap_pgbuf(mdb);
|
mdb_swap_pgbuf(mdb);
|
||||||
return text;
|
return text;
|
||||||
|
/*
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr,"Unhandled memo field flags = %04x\n", memo_flags);
|
fprintf(stderr,"Unhandled memo field flags = %04x\n", memo_flags);
|
||||||
return "";
|
return "";
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
#if 0
|
#if 0
|
||||||
strncpy(text, &mdb->pg_buf[start + MDB_MEMO_OVERHEAD],
|
strncpy(text, &mdb->pg_buf[start + MDB_MEMO_OVERHEAD],
|
||||||
@ -491,12 +540,45 @@ guint16 len;
|
|||||||
return text;
|
return text;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
char *mdb_num_to_string(MdbHandle *mdb, int start, int datatype, int prec, int scale)
|
||||||
|
{
|
||||||
|
/* FIX ME -- not thread safe */
|
||||||
|
static char text[MDB_BIND_SIZE];
|
||||||
|
char tmpbuf[MDB_BIND_SIZE];
|
||||||
|
char mask[20];
|
||||||
|
gint32 l, whole, fraction;
|
||||||
|
|
||||||
|
l = mdb->pg_buf[start+16] * 256 * 256 * 256 +
|
||||||
|
mdb->pg_buf[start+15] * 256 * 256 +
|
||||||
|
mdb->pg_buf[start+14] * 256 +
|
||||||
|
mdb->pg_buf[start+13];
|
||||||
|
|
||||||
|
sprintf(mask,"%%0%ldld",prec);
|
||||||
|
sprintf(tmpbuf,mask,l);
|
||||||
|
//strcpy(text, tmpbuf);
|
||||||
|
//return text;
|
||||||
|
if (!scale) {
|
||||||
|
strcpy(text,tmpbuf);
|
||||||
|
} else {
|
||||||
|
memset(text,0,sizeof(text));
|
||||||
|
strncpy(text,tmpbuf,prec-scale);
|
||||||
|
strcat(text,".");
|
||||||
|
strcat(text,&tmpbuf[strlen(tmpbuf)-scale]);
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
for (i=0;i<size;i++) {
|
||||||
|
fprintf(stdout, "%c %02x ", isprint(mdb->pg_buf[start+i]) ? mdb->pg_buf[start+i] : '.', mdb->pg_buf[start+i]);
|
||||||
|
}
|
||||||
|
fprintf(stdout, "\n");
|
||||||
|
*/
|
||||||
|
return text;
|
||||||
|
}
|
||||||
char *mdb_col_to_string(MdbHandle *mdb, int start, int datatype, int size)
|
char *mdb_col_to_string(MdbHandle *mdb, int start, int datatype, int size)
|
||||||
{
|
{
|
||||||
/* FIX ME -- not thread safe */
|
/* FIX ME -- not thread safe */
|
||||||
static char text[MDB_BIND_SIZE];
|
static char text[MDB_BIND_SIZE];
|
||||||
time_t t;
|
time_t t;
|
||||||
int i;
|
int i,j;
|
||||||
|
|
||||||
switch (datatype) {
|
switch (datatype) {
|
||||||
case MDB_BOOL:
|
case MDB_BOOL:
|
||||||
@ -508,7 +590,7 @@ int i;
|
|||||||
return text;
|
return text;
|
||||||
break;
|
break;
|
||||||
case MDB_INT:
|
case MDB_INT:
|
||||||
sprintf(text,"%ld",mdb_get_int16(mdb, start));
|
sprintf(text,"%ld",(long)mdb_get_int16(mdb, start));
|
||||||
return text;
|
return text;
|
||||||
break;
|
break;
|
||||||
case MDB_LONGINT:
|
case MDB_LONGINT:
|
||||||
@ -563,6 +645,7 @@ int i;
|
|||||||
case MDB_MONEY:
|
case MDB_MONEY:
|
||||||
mdb_money_to_string(mdb, start, text);
|
mdb_money_to_string(mdb, start, text);
|
||||||
return text;
|
return text;
|
||||||
|
case MDB_NUMERIC:
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return "";
|
return "";
|
||||||
|
@ -142,7 +142,7 @@ off_t offset = pg * mdb->pg_size;
|
|||||||
}
|
}
|
||||||
return len;
|
return len;
|
||||||
}
|
}
|
||||||
mdb_swap_pgbuf(MdbHandle *mdb)
|
void mdb_swap_pgbuf(MdbHandle *mdb)
|
||||||
{
|
{
|
||||||
char tmpbuf[MDB_PGSIZE];
|
char tmpbuf[MDB_PGSIZE];
|
||||||
|
|
||||||
|
@ -95,12 +95,20 @@ GSList *slist = NULL;
|
|||||||
** column attributes
|
** column attributes
|
||||||
*/
|
*/
|
||||||
for (i=0;i<table->num_cols;i++) {
|
for (i=0;i<table->num_cols;i++) {
|
||||||
|
#ifdef MDB_DEBUG
|
||||||
|
/* printf("column %d\n", i);
|
||||||
|
buffer_dump(mdb->pg_buf, cur_col ,cur_col + 18); */
|
||||||
|
#endif
|
||||||
memset(&col, 0, sizeof(col));
|
memset(&col, 0, sizeof(col));
|
||||||
col.col_num = mdb->pg_buf[cur_col + mdb->col_num_offset];
|
col.col_num = mdb->pg_buf[cur_col + mdb->col_num_offset];
|
||||||
|
|
||||||
read_pg_if(mdb, &cur_col, 0);
|
read_pg_if(mdb, &cur_col, 0);
|
||||||
col.col_type = mdb->pg_buf[cur_col];
|
col.col_type = mdb->pg_buf[cur_col];
|
||||||
|
|
||||||
|
if (col.col_type == MDB_NUMERIC) {
|
||||||
|
col.col_prec = mdb->pg_buf[cur_col + 11];
|
||||||
|
col.col_scale = mdb->pg_buf[cur_col + 12];
|
||||||
|
}
|
||||||
|
|
||||||
read_pg_if(mdb, &cur_col, 13);
|
read_pg_if(mdb, &cur_col, 13);
|
||||||
col.is_fixed = mdb->pg_buf[cur_col + mdb->col_fixed_offset] &
|
col.is_fixed = mdb->pg_buf[cur_col + mdb->col_fixed_offset] &
|
||||||
|
@ -36,6 +36,7 @@ char *delimiter = ",";
|
|||||||
char header_row = 1;
|
char header_row = 1;
|
||||||
char quote_text = 1;
|
char quote_text = 1;
|
||||||
int opt;
|
int opt;
|
||||||
|
char *s;
|
||||||
|
|
||||||
while ((opt=getopt(argc, argv, "HQd:"))!=-1) {
|
while ((opt=getopt(argc, argv, "HQd:"))!=-1) {
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
@ -100,14 +101,26 @@ int opt;
|
|||||||
|
|
||||||
while(mdb_fetch_row(table)) {
|
while(mdb_fetch_row(table)) {
|
||||||
if (quote_text && is_text_type(col->col_type)) {
|
if (quote_text && is_text_type(col->col_type)) {
|
||||||
fprintf(stdout,"\"%s\"",bound_values[0]);
|
fprintf(stdout,"\"");
|
||||||
|
for (s=bound_values[0];*s;s++) {
|
||||||
|
if (*s=='"') fprintf(stdout,"\"\"");
|
||||||
|
else fprintf(stdout,"%c",*s);
|
||||||
|
}
|
||||||
|
fprintf(stdout,"\"");
|
||||||
|
/* fprintf(stdout,"\"%s\"",bound_values[0]); */
|
||||||
} else {
|
} else {
|
||||||
fprintf(stdout,"%s",bound_values[0]);
|
fprintf(stdout,"%s",bound_values[0]);
|
||||||
}
|
}
|
||||||
for (j=1;j<table->num_cols;j++) {
|
for (j=1;j<table->num_cols;j++) {
|
||||||
col=g_ptr_array_index(table->columns,j);
|
col=g_ptr_array_index(table->columns,j);
|
||||||
if (quote_text && is_text_type(col->col_type)) {
|
if (quote_text && is_text_type(col->col_type)) {
|
||||||
fprintf(stdout,"%s\"%s\"",delimiter,bound_values[j]);
|
fprintf(stdout,"%s",delimiter);
|
||||||
|
fprintf(stdout,"\"");
|
||||||
|
for (s=bound_values[j];*s;s++) {
|
||||||
|
if (*s=='"') fprintf(stdout,"\"\"");
|
||||||
|
else fprintf(stdout,"%c",*s);
|
||||||
|
}
|
||||||
|
fprintf(stdout,"\"");
|
||||||
} else {
|
} else {
|
||||||
fprintf(stdout,"%s%s",delimiter,bound_values[j]);
|
fprintf(stdout,"%s%s",delimiter,bound_values[j]);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user