mirror of
https://github.com/mdbtools/mdbtools.git
synced 2025-04-05 20:31:00 +08:00
signature change to mdb_open()
This commit is contained in:
parent
04452fbafe
commit
4953cee0af
28
ChangeLog
28
ChangeLog
@ -1,3 +1,31 @@
|
||||
Tue Apr 13 15:25:26 EDT 2004 Brian Bruns <brian@bruns.com>
|
||||
* include/mdbtools.h:
|
||||
* src/sql/mdbsql.c:
|
||||
* src/util/mdb-array.c:
|
||||
* src/util/mdb-check.c:
|
||||
* src/util/mdb-export.c:
|
||||
* src/util/mdb-header.c:
|
||||
* src/util/mdb-import.c:
|
||||
* src/util/mdb-prop.c:
|
||||
* src/util/mdb-schema.c:
|
||||
* src/util/mdb-tables.c:
|
||||
* src/util/mdb-ver.c:
|
||||
* src/util/prcat.c:
|
||||
* src/util/prdata.c:
|
||||
* src/util/prdump.c:
|
||||
* src/util/prfreemap.c:
|
||||
* src/util/prindex.c:
|
||||
* src/util/prkkd.c:
|
||||
* src/util/prole.c:
|
||||
* src/util/prtable.c:
|
||||
* src/util/sargtest.c:
|
||||
* src/util/updrow.c:
|
||||
* src/gmdb/file.c:
|
||||
* src/gmdb2/file.c:
|
||||
* src/libmdb/file.c: Add flags argument to mdb_open to support read/write
|
||||
files
|
||||
* doc/reference/libmdb/libmdb-sections.txt: Organize reference manual a little better
|
||||
|
||||
Mon Apr 12 21:58:00 CDT 2004 Jeff Smith <whydoubt@yahoo.com>
|
||||
* src/odbc/connectparams.c: ODBC driver dialog enhancements
|
||||
* src/sql/mdbsql.c: Correct some array sizes
|
||||
|
@ -25,24 +25,101 @@ MdbProperties
|
||||
MdbColumn
|
||||
mdbsargtree
|
||||
MdbIndexPage
|
||||
gpointer)
|
||||
MDB_MAX_INDEX_DEPTH
|
||||
MdbIndexChain
|
||||
MdbTableDef
|
||||
MdbColumnProp
|
||||
MdbField
|
||||
MdbSarg
|
||||
<SUBSECTION>
|
||||
mdb_init
|
||||
mdb_open
|
||||
mdb_close
|
||||
mdb_clone_handle
|
||||
mdb_exit
|
||||
mdb_alloc_handle
|
||||
mdb_free_handle
|
||||
<SUBSECTION>
|
||||
mdb_read_catalog
|
||||
mdb_dump_catalog
|
||||
mdb_free_catalog
|
||||
mdb_alloc_tabledef
|
||||
mdb_alloc_catalog
|
||||
mdb_alloc_file
|
||||
mdb_free_file
|
||||
<SUBSECTION>
|
||||
mdb_read_table
|
||||
mdb_rewind_table
|
||||
mdb_table_dump
|
||||
mdb_free_tabledef
|
||||
<SUBSECTION>
|
||||
mdb_read_columns
|
||||
mdb_append_index
|
||||
mdb_get_objtype_string
|
||||
mdb_bind_column_by_name
|
||||
mdb_data_dump
|
||||
mdb_bind_column
|
||||
mdb_fetch_row
|
||||
mdb_is_fixed_col
|
||||
mdb_col_to_string
|
||||
mdb_find_end_of_row
|
||||
mdb_col_fixed_size
|
||||
mdb_col_disp_size
|
||||
mdb_bind_len
|
||||
mdb_ole_read_next
|
||||
mdb_ole_read
|
||||
mdb_set_date_fmt
|
||||
mdb_read_row
|
||||
mdb_get_coltype_string
|
||||
mdb_coltype_takes_length
|
||||
mdb_init_backends
|
||||
mdb_register_backend
|
||||
mdb_remove_backends
|
||||
mdb_set_default_backend
|
||||
mdb_get_relationships
|
||||
mdb_sql_walk_tree
|
||||
mdb_find_indexable_sargs
|
||||
mdb_add_sarg_by_name
|
||||
<SUBSECTION>
|
||||
mdb_read_indices
|
||||
mdb_index_dump
|
||||
mdb_index_scan_free
|
||||
mdb_index_find_next_on_page
|
||||
mdb_index_find_next
|
||||
mdb_index_hash_text
|
||||
mdb_index_scan_init
|
||||
mdb_index_find_row
|
||||
<SUBSECTION>
|
||||
mdb_stats_on
|
||||
mdb_stats_off
|
||||
mdb_dump_stats
|
||||
<SUBSECTION>
|
||||
mdb_like_cmp
|
||||
mdb_crack_row
|
||||
mdb_add_row_to_pg
|
||||
mdb_update_index
|
||||
mdb_pack_row
|
||||
mdb_replace_row
|
||||
mdb_pg_get_freespace
|
||||
mdb_update_row
|
||||
mdb_new_data_pg
|
||||
mdb_map_find_next_freepage
|
||||
<SUBSECTION>
|
||||
mdb_read_props_list
|
||||
mdb_free_props
|
||||
mdb_read_props
|
||||
<SUBSECTION>
|
||||
mdb_create_temp_table
|
||||
mdb_temp_table_add_col
|
||||
mdb_fill_temp_col
|
||||
mdb_fill_temp_field
|
||||
<SUBSECTION>
|
||||
mdb_get_option
|
||||
mdb_debug
|
||||
<SUBSECTION>
|
||||
mdb_unicode2ascii
|
||||
mdb_ascii2unicode
|
||||
<SUBSECTION Private>
|
||||
mdb_alloc_stats
|
||||
mdb_alloc_handle
|
||||
mdb_test_string
|
||||
mdb_test_int
|
||||
mdb_add_sarg
|
||||
buffer_dump
|
||||
mdb_read_pg
|
||||
mdb_read_alt_pg
|
||||
mdb_get_byte
|
||||
@ -58,87 +135,18 @@ mdb_pg_get_int32
|
||||
mdb_pg_get_single
|
||||
mdb_pg_get_double
|
||||
mdb_pg_get_int24_msb
|
||||
mdb_open
|
||||
mdb_close
|
||||
mdb_clone_handle
|
||||
mdb_swap_pgbuf
|
||||
mdb_free_tabledef
|
||||
mdb_read_catalog
|
||||
mdb_catalog_dump
|
||||
mdb_catalog_rows
|
||||
mdb_get_catalog_entry
|
||||
mdb_get_objtype_string
|
||||
mdb_dump_catalog
|
||||
mdb_read_table
|
||||
mdb_read_columns
|
||||
mdb_table_dump
|
||||
mdb_index_swap_n
|
||||
mdb_test_sargs
|
||||
mdb_test_sarg
|
||||
read_pg_if_16
|
||||
read_pg_if_32
|
||||
read_pg_if
|
||||
read_pg_if_n
|
||||
mdb_bind_column_by_name
|
||||
mdb_data_dump
|
||||
mdb_bind_column
|
||||
mdb_rewind_table
|
||||
mdb_fetch_row
|
||||
mdb_is_fixed_col
|
||||
mdb_col_to_string
|
||||
mdb_find_end_of_row
|
||||
mdb_col_fixed_size
|
||||
mdb_col_disp_size
|
||||
mdb_bind_len
|
||||
mdb_ole_read_next
|
||||
mdb_ole_read
|
||||
mdb_set_date_fmt
|
||||
mdb_read_row
|
||||
buffer_dump
|
||||
mdb_get_coltype_string
|
||||
mdb_coltype_takes_length
|
||||
mdb_init_backends
|
||||
mdb_register_backend
|
||||
mdb_remove_backends
|
||||
mdb_set_default_backend
|
||||
mdb_get_relationships
|
||||
mdb_test_sargs
|
||||
mdb_test_sarg
|
||||
mdb_sql_walk_tree
|
||||
mdb_find_indexable_sargs
|
||||
mdb_add_sarg_by_name
|
||||
mdb_test_string
|
||||
mdb_test_int
|
||||
mdb_add_sarg
|
||||
mdb_read_indices
|
||||
mdb_index_dump
|
||||
mdb_index_scan_free
|
||||
mdb_index_find_next_on_page
|
||||
mdb_index_find_next
|
||||
mdb_index_hash_text
|
||||
mdb_index_scan_init
|
||||
mdb_index_find_row
|
||||
mdb_index_swap_n
|
||||
mdb_stats_on
|
||||
mdb_stats_off
|
||||
mdb_dump_stats
|
||||
mdb_like_cmp
|
||||
mdb_crack_row
|
||||
mdb_add_row_to_pg
|
||||
mdb_update_index
|
||||
mdb_pack_row
|
||||
mdb_replace_row
|
||||
mdb_pg_get_freespace
|
||||
mdb_update_row
|
||||
mdb_new_data_pg
|
||||
mdb_map_find_next_freepage
|
||||
mdb_read_props_list
|
||||
mdb_free_props
|
||||
mdb_read_props
|
||||
mdb_create_temp_table
|
||||
mdb_temp_table_add_col
|
||||
mdb_fill_temp_col
|
||||
mdb_fill_temp_field
|
||||
mdb_get_option
|
||||
mdb_debug
|
||||
mdb_unicode2ascii
|
||||
mdb_ascii2unicode
|
||||
mdb_alloc_file
|
||||
mdb_free_file
|
||||
mdb_alloc_tabledef
|
||||
mdb_alloc_catalog
|
||||
mdb_free_handle
|
||||
</SECTION>
|
||||
|
||||
|
@ -105,6 +105,11 @@ typedef enum {
|
||||
MDB_INDEX_SCAN
|
||||
} MdbStrategy;
|
||||
|
||||
typedef enum {
|
||||
MDB_NOFLAGS = 0x00,
|
||||
MDB_WRITABLE = 0x01
|
||||
} MdbFileFlags;
|
||||
|
||||
enum {
|
||||
MDB_DEBUG_LIKE = 0x0001,
|
||||
MDB_DEBUG_WRITE = 0x0002,
|
||||
@ -292,7 +297,7 @@ typedef struct {
|
||||
unsigned char cache_value[256];
|
||||
} MdbIndexPage;
|
||||
|
||||
typedef int MdbSargTreeFunc(MdbSargNode *, gpointer);
|
||||
typedef int MdbSargTreeFunc(MdbSargNode *, gpointer *data);
|
||||
|
||||
#define MDB_MAX_INDEX_DEPTH 10
|
||||
|
||||
@ -396,8 +401,7 @@ extern long mdb_pg_get_int32(MdbHandle *mdb, int offset);
|
||||
extern float mdb_pg_get_single(MdbHandle *mdb, int offset);
|
||||
extern double mdb_pg_get_double(MdbHandle *mdb, int offset);
|
||||
extern gint32 mdb_pg_get_int24_msb(MdbHandle *mdb, int offset);
|
||||
extern MdbHandle *mdb_open(char *filename);
|
||||
extern MdbHandle *_mdb_open(char *filename, gboolean writable);
|
||||
extern MdbHandle *mdb_open(char *filename, MdbFileFlags flags);
|
||||
extern void mdb_close(MdbHandle *mdb);
|
||||
extern MdbHandle *mdb_clone_handle(MdbHandle *mdb);
|
||||
extern void mdb_swap_pgbuf(MdbHandle *mdb);
|
||||
@ -406,9 +410,7 @@ extern void mdb_free_tabledef(MdbTableDef *table);
|
||||
|
||||
/* catalog.c */
|
||||
GPtrArray *mdb_read_catalog(MdbHandle *mdb, int obj_type);
|
||||
extern void mdb_catalog_dump(MdbHandle *mdb, int obj_type);
|
||||
extern int mdb_catalog_rows(MdbHandle *mdb);
|
||||
extern MdbCatalogEntry *mdb_get_catalog_entry(MdbHandle *mdb, int rowid, MdbCatalogEntry *entry);
|
||||
extern void mdb_dump_catalog(MdbHandle *mdb, int obj_type);
|
||||
extern char *mdb_get_objtype_string(int obj_type);
|
||||
extern void mdb_dump_catalog(MdbHandle *mdb, int obj_type);
|
||||
|
||||
|
@ -8,7 +8,7 @@ extern int main_show_debug;
|
||||
void
|
||||
gmdb_file_open(gchar *file_path)
|
||||
{
|
||||
mdb = mdb_open(file_path);
|
||||
mdb = mdb_open(file_path, MDB_NOFLAGS);
|
||||
if (!mdb) {
|
||||
gmdb_info_msg("Unable to open file.");
|
||||
return;
|
||||
|
@ -107,7 +107,7 @@ gmdb_file_open(gchar *file_path)
|
||||
int i;
|
||||
|
||||
gmdb_reset_widgets();
|
||||
mdb = mdb_open(file_path);
|
||||
mdb = mdb_open(file_path, MDB_NOFLAGS);
|
||||
if (!mdb) {
|
||||
gnome_warning_dialog("Unable to open file.");
|
||||
return;
|
||||
|
@ -93,7 +93,18 @@ int ret;
|
||||
} while ((dir = strtok(NULL, ":")));
|
||||
return -1;
|
||||
}
|
||||
MdbHandle *_mdb_open(char *filename, gboolean writable)
|
||||
/**
|
||||
* mdb_open:
|
||||
* @filename: path to MDB (database) file
|
||||
* @flags: MDB_NOFLAGS for read-only, MDB_WRITABLE for read/write
|
||||
*
|
||||
* Opens an MDB file and returns an MdbHandle to it. MDB File may be relative
|
||||
* to the current directory, a full path to the file, or relative to a
|
||||
* component of $MDBPATH.
|
||||
*
|
||||
* Return value: pointer to MdbHandle structure.
|
||||
**/
|
||||
MdbHandle *mdb_open(char *filename, MdbFileFlags flags)
|
||||
{
|
||||
MdbHandle *mdb;
|
||||
int bufsize;
|
||||
@ -117,7 +128,7 @@ MdbFile *f;
|
||||
}
|
||||
}
|
||||
//strcpy(f->filename, filename);
|
||||
if (writable) {
|
||||
if (flags & MDB_WRITABLE) {
|
||||
f->writable = TRUE;
|
||||
f->fd = open(f->filename,O_RDWR);
|
||||
} else {
|
||||
@ -149,21 +160,14 @@ MdbFile *f;
|
||||
f->refs++;
|
||||
return mdb;
|
||||
}
|
||||
/**
|
||||
* mdb_open:
|
||||
* @filename: path to MDB (database) file
|
||||
*
|
||||
* Opens an MDB file and returns an MdbHandle to it. MDB File may be relative
|
||||
* to the current directory, a full path to the file, or relative to a
|
||||
* component of $MDBPATH.
|
||||
*
|
||||
* Return value: pointer to MdbHandle structure.
|
||||
**/
|
||||
MdbHandle *mdb_open(char *filename)
|
||||
{
|
||||
return _mdb_open(filename, FALSE);
|
||||
}
|
||||
|
||||
/**
|
||||
* mdb_close:
|
||||
* @mdb: Handle to open MDB database file
|
||||
*
|
||||
* Dereferences MDB file, closes if reference count is 0, and destroys handle.
|
||||
*
|
||||
**/
|
||||
void
|
||||
mdb_close(MdbHandle *mdb)
|
||||
{
|
||||
@ -175,6 +179,15 @@ mdb_close(MdbHandle *mdb)
|
||||
}
|
||||
}
|
||||
}
|
||||
/**
|
||||
* mdb_clone_handle:
|
||||
* @mdb: Handle to open MDB database file
|
||||
*
|
||||
* Clones an existing database handle. Cloned handle shares the file descriptor
|
||||
* but has it's own page buffer, page position, and similar internal variables.
|
||||
*
|
||||
* Return value: new handle to the database.
|
||||
*/
|
||||
MdbHandle *mdb_clone_handle(MdbHandle *mdb)
|
||||
{
|
||||
MdbHandle *newmdb;
|
||||
|
@ -152,12 +152,12 @@ wordexp_t words;
|
||||
|
||||
#endif
|
||||
|
||||
if (!(sql->mdb = mdb_open(db_namep))) {
|
||||
if (!(sql->mdb = mdb_open(db_namep, MDB_NOFLAGS))) {
|
||||
if (!strstr(db_namep, ".mdb")) {
|
||||
char *tmpstr = (char *) malloc(strlen(db_namep)+5);
|
||||
strcpy(tmpstr,db_namep);
|
||||
strcat(tmpstr,".mdb");
|
||||
if (!(sql->mdb = mdb_open(tmpstr))) {
|
||||
if (!(sql->mdb = mdb_open(tmpstr, MDB_NOFLAGS))) {
|
||||
fail++;
|
||||
}
|
||||
free(tmpstr);
|
||||
|
@ -49,7 +49,7 @@ int started;
|
||||
}
|
||||
|
||||
mdb_init();
|
||||
mdb = mdb_open (argv [1]);
|
||||
mdb = mdb_open (argv [1], MDB_NOFLAGS);
|
||||
|
||||
mdb_read_catalog (mdb, MDB_TABLE);
|
||||
|
||||
|
@ -65,7 +65,7 @@ int opt;
|
||||
|
||||
/* open the database */
|
||||
|
||||
mdb = mdb_open (argv[optind]);
|
||||
mdb = mdb_open (argv[optind], MDB_NOFLAGS);
|
||||
|
||||
/* read the catalog */
|
||||
|
||||
|
@ -115,7 +115,7 @@ main(int argc, char **argv)
|
||||
|
||||
mdb_init();
|
||||
|
||||
if (!(mdb = mdb_open(argv[optind]))) {
|
||||
if (!(mdb = mdb_open(argv[optind], MDB_NOFLAGS))) {
|
||||
exit(1);
|
||||
}
|
||||
|
||||
|
@ -53,7 +53,7 @@ FILE *cfile;
|
||||
|
||||
/* open the database */
|
||||
|
||||
mdb = mdb_open (argv[1]);
|
||||
mdb = mdb_open (argv[1], MDB_NOFLAGS);
|
||||
if (!mdb) {
|
||||
mdb_exit();
|
||||
exit(1);
|
||||
|
@ -191,7 +191,7 @@ main(int argc, char **argv)
|
||||
|
||||
mdb_init();
|
||||
|
||||
if (!(mdb = _mdb_open(argv[optind], TRUE))) {
|
||||
if (!(mdb = mdb_open(argv[optind], MDB_WRITABLE))) {
|
||||
exit(1);
|
||||
}
|
||||
|
||||
|
@ -54,7 +54,7 @@ main(int argc, char **argv)
|
||||
|
||||
mdb_init();
|
||||
|
||||
if (!(mdb = mdb_open(argv[optind]))) {
|
||||
if (!(mdb = mdb_open(argv[optind], MDB_NOFLAGS))) {
|
||||
exit(1);
|
||||
}
|
||||
mdb_read_catalog(mdb, MDB_TABLE);
|
||||
|
@ -68,7 +68,7 @@ main (int argc, char **argv)
|
||||
|
||||
/* open the database */
|
||||
|
||||
mdb = mdb_open (argv[optind]);
|
||||
mdb = mdb_open (argv[optind], MDB_NOFLAGS);
|
||||
if (argc - optind >= 2) {
|
||||
if (!mdb_set_default_backend(mdb, argv[optind + 1])) {
|
||||
fprintf(stderr,"Invalid backend type\n");
|
||||
|
@ -58,7 +58,7 @@ int opt;
|
||||
mdb_init();
|
||||
|
||||
/* open the database */
|
||||
if (!(mdb = mdb_open (argv[optind]))) {
|
||||
if (!(mdb = mdb_open (argv[optind], MDB_NOFLAGS))) {
|
||||
fprintf(stderr,"Couldn't open database.\n");
|
||||
exit(1);
|
||||
}
|
||||
|
@ -62,7 +62,7 @@ main(int argc, char **argv)
|
||||
|
||||
mdb_init();
|
||||
|
||||
if (!(mdb = mdb_open(argv[optind]))) {
|
||||
if (!(mdb = mdb_open(argv[optind], MDB_NOFLAGS))) {
|
||||
fprintf(stderr,_("Error: unable to open file %s\n"),argv[optind]);
|
||||
exit(1);
|
||||
}
|
||||
|
@ -31,7 +31,7 @@ main(int argc, char **argv)
|
||||
|
||||
mdb_init();
|
||||
|
||||
mdb = mdb_open(argv[1]);
|
||||
mdb = mdb_open(argv[1], MDB_NOFLAGS);
|
||||
|
||||
mdb_dump_catalog(mdb,(argc > 2) ? atoi(argv[2]) : MDB_TABLE);
|
||||
|
||||
|
@ -34,7 +34,7 @@ MdbTableDef *table;
|
||||
}
|
||||
|
||||
mdb_init();
|
||||
mdb = mdb_open(argv[1]);
|
||||
mdb = mdb_open(argv[1], MDB_NOFLAGS);
|
||||
|
||||
mdb_read_catalog(mdb, MDB_TABLE);
|
||||
|
||||
|
@ -33,7 +33,7 @@ int page, start, stop;
|
||||
}
|
||||
|
||||
mdb_init();
|
||||
mdb = mdb_open(argv[1]);
|
||||
mdb = mdb_open(argv[1], MDB_NOFLAGS);
|
||||
|
||||
mdb_read_catalog(mdb, MDB_TABLE);
|
||||
|
||||
|
@ -35,7 +35,7 @@ unsigned char *map_buf;
|
||||
}
|
||||
|
||||
mdb_init();
|
||||
mdb = mdb_open(argv[1]);
|
||||
mdb = mdb_open(argv[1], MDB_NOFLAGS);
|
||||
|
||||
mdb_read_pg (mdb, 1);
|
||||
row_start = mdb_get_int16(mdb, (mdb->fmt->row_count_offset + 2));
|
||||
|
@ -40,7 +40,7 @@ int found = 0;
|
||||
}
|
||||
|
||||
mdb_init();
|
||||
if (!(mdb = mdb_open(argv[1]))) {
|
||||
if (!(mdb = mdb_open(argv[1], MDB_NOFLAGS))) {
|
||||
fprintf(stderr,"Unable to open database.\n");
|
||||
exit(1);
|
||||
}
|
||||
|
@ -32,7 +32,7 @@ main(int argc, char **argv)
|
||||
}
|
||||
|
||||
mdb_init();
|
||||
mdb = mdb_open(argv[1]);
|
||||
mdb = mdb_open(argv[1], MDB_NOFLAGS);
|
||||
|
||||
mdb_read_pg(mdb, MDB_CATALOG_PG);
|
||||
rows = mdb_catalog_rows(mdb);
|
||||
|
@ -39,7 +39,7 @@ char *sargname = NULL;
|
||||
}
|
||||
|
||||
mdb_init();
|
||||
mdb = mdb_open(argv[1]);
|
||||
mdb = mdb_open(argv[1], MDB_NOFLAGS);
|
||||
dot = strchr(argv[2],'.');
|
||||
if (argc>3) sargname = argv[3];
|
||||
|
||||
|
@ -35,7 +35,7 @@ int found = 0;
|
||||
}
|
||||
|
||||
mdb_init();
|
||||
mdb = mdb_open(argv[1]);
|
||||
mdb = mdb_open(argv[1], MDB_NOFLAGS);
|
||||
|
||||
mdb_read_catalog(mdb, MDB_TABLE);
|
||||
|
||||
|
@ -37,7 +37,7 @@ MdbTableDef *table;
|
||||
|
||||
mdb_init();
|
||||
|
||||
if (!(mdb = mdb_open(MDB_FILE))) {
|
||||
if (!(mdb = mdb_open(MDB_FILE, MDB_NOFLAGS))) {
|
||||
exit(1);
|
||||
}
|
||||
|
||||
|
@ -44,7 +44,7 @@ int len;
|
||||
}
|
||||
|
||||
mdb_init();
|
||||
mdb = _mdb_open(argv[1], TRUE);
|
||||
mdb = mdb_open(argv[1], MDB_WRITABLE);
|
||||
tabname = argv[2];
|
||||
sargname = argv[3];
|
||||
updstr = strdup(argv[4]);
|
||||
|
Loading…
Reference in New Issue
Block a user