mirror of
https://github.com/mdbtools/mdbtools.git
synced 2025-11-26 02:09:49 +08:00
Deprecate more mdb_{init|remove}_backends
These functions now use the __attribute__((constructor)) & destructor. Old names were keep for compatibility Also put __attribute__((deprecated)) in mdbtools.h for all deprecated functions.
This commit is contained in:
@@ -416,8 +416,8 @@ typedef struct {
|
|||||||
} MdbSarg;
|
} MdbSarg;
|
||||||
|
|
||||||
/* mem.c */
|
/* mem.c */
|
||||||
extern void mdb_init(); // DEPRECATED
|
extern void __attribute__((deprecated)) mdb_init();
|
||||||
extern void mdb_exit(); // DEPRECATED
|
extern void __attribute__((deprecated)) mdb_exit();
|
||||||
|
|
||||||
/* file.c */
|
/* file.c */
|
||||||
extern ssize_t mdb_read_pg(MdbHandle *mdb, unsigned long pg);
|
extern ssize_t mdb_read_pg(MdbHandle *mdb, unsigned long pg);
|
||||||
@@ -487,14 +487,14 @@ extern int mdb_read_row(MdbTableDef *table, unsigned int row);
|
|||||||
extern void mdb_buffer_dump(const void *buf, int start, size_t len);
|
extern void mdb_buffer_dump(const void *buf, int start, size_t len);
|
||||||
|
|
||||||
/* backend.c */
|
/* backend.c */
|
||||||
extern char* mdb_get_coltype_string(MdbBackend *backend, int col_type); /* obsolete */
|
extern char* __attribute__((deprecated)) mdb_get_coltype_string(MdbBackend *backend, int col_type);
|
||||||
extern int mdb_coltype_takes_length(MdbBackend *backend, int col_type); /* obsolete */
|
extern int __attribute__((deprecated)) mdb_coltype_takes_length(MdbBackend *backend, int col_type);
|
||||||
extern const MdbBackendType* mdb_get_colbacktype(const MdbColumn *col);
|
extern const MdbBackendType* mdb_get_colbacktype(const MdbColumn *col);
|
||||||
extern const char* mdb_get_colbacktype_string(const MdbColumn *col);
|
extern const char* mdb_get_colbacktype_string(const MdbColumn *col);
|
||||||
extern int mdb_colbacktype_takes_length(const MdbColumn *col);
|
extern int mdb_colbacktype_takes_length(const MdbColumn *col);
|
||||||
extern void mdb_init_backends();
|
extern void __attribute__((deprecated)) mdb_init_backends();
|
||||||
extern void mdb_register_backend(char *backend_name, guint32 capabilities, MdbBackendType *backend_type, MdbBackendType *type_shortdate, MdbBackendType *type_autonum, const char *short_now, const char *long_now, const char *charset_statement, const char *drop_statement, const char *constaint_not_empty_statement, const char *column_comment_statement, const char *table_comment_statement, gchar* (*quote_schema_name)(const gchar*, const gchar*));
|
extern void mdb_register_backend(char *backend_name, guint32 capabilities, MdbBackendType *backend_type, MdbBackendType *type_shortdate, MdbBackendType *type_autonum, const char *short_now, const char *long_now, const char *charset_statement, const char *drop_statement, const char *constaint_not_empty_statement, const char *column_comment_statement, const char *table_comment_statement, gchar* (*quote_schema_name)(const gchar*, const gchar*));
|
||||||
extern void mdb_remove_backends();
|
extern void __attribute__((deprecated)) mdb_remove_backends();
|
||||||
extern int mdb_set_default_backend(MdbHandle *mdb, const char *backend_name);
|
extern int mdb_set_default_backend(MdbHandle *mdb, const char *backend_name);
|
||||||
extern void mdb_print_schema(MdbHandle *mdb, FILE *outfile, char *tabname, char *dbnamespace, guint32 export_options);
|
extern void mdb_print_schema(MdbHandle *mdb, FILE *outfile, char *tabname, char *dbnamespace, guint32 export_options);
|
||||||
|
|
||||||
|
|||||||
@@ -237,7 +237,7 @@ quote_with_squotes(const gchar* value)
|
|||||||
return quote_generic(value, '\'', '\'');
|
return quote_generic(value, '\'', '\'');
|
||||||
}
|
}
|
||||||
|
|
||||||
/* deprecated */ char *
|
char * __attribute__((deprecated))
|
||||||
mdb_get_coltype_string(MdbBackend *backend, int col_type)
|
mdb_get_coltype_string(MdbBackend *backend, int col_type)
|
||||||
{
|
{
|
||||||
static int warn_deprecated = 0;
|
static int warn_deprecated = 0;
|
||||||
@@ -255,7 +255,7 @@ mdb_get_coltype_string(MdbBackend *backend, int col_type)
|
|||||||
return backend->types_table[col_type].name;
|
return backend->types_table[col_type].name;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* deprecated */ int
|
int __attribute__((deprecated))
|
||||||
mdb_coltype_takes_length(MdbBackend *backend, int col_type)
|
mdb_coltype_takes_length(MdbBackend *backend, int col_type)
|
||||||
{
|
{
|
||||||
static int warn_deprecated = 0;
|
static int warn_deprecated = 0;
|
||||||
@@ -303,13 +303,17 @@ mdb_colbacktype_takes_length(const MdbColumn *col)
|
|||||||
return type->needs_length;
|
return type->needs_length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void __attribute__((deprecated)) mdb_init_backends() {
|
||||||
|
fprintf(stderr, "mdb_init_backends() is DEPRECATED and does nothing. Stop calling it.\n");
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* mdb_init_backends
|
* _mdb_init_backends
|
||||||
*
|
*
|
||||||
* Initializes the mdb_backends hash and loads the builtin backends.
|
* Initializes the mdb_backends hash and loads the builtin backends.
|
||||||
* Use mdb_remove_backends() to destroy this hash when done.
|
* Use mdb_remove_backends() to destroy this hash when done.
|
||||||
*/
|
*/
|
||||||
void mdb_init_backends()
|
void __attribute__ ((constructor)) _mdb_init_backends()
|
||||||
{
|
{
|
||||||
mdb_backends = g_hash_table_new(g_str_hash, g_str_equal);
|
mdb_backends = g_hash_table_new(g_str_hash, g_str_equal);
|
||||||
|
|
||||||
@@ -382,12 +386,16 @@ void mdb_register_backend(char *backend_name, guint32 capabilities, MdbBackendTy
|
|||||||
g_hash_table_insert(mdb_backends, backend_name, backend);
|
g_hash_table_insert(mdb_backends, backend_name, backend);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void __attribute__((deprecated)) mdb_remove_backends() {
|
||||||
|
fprintf(stderr, "mdb_remove_backends() is DEPRECATED and does nothing. Stop calling it.\n");
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* mdb_remove_backends
|
* mdb_remove_backends
|
||||||
*
|
*
|
||||||
* Removes all entries from and destroys the mdb_backends hash.
|
* Removes all entries from and destroys the mdb_backends hash.
|
||||||
*/
|
*/
|
||||||
void mdb_remove_backends()
|
void __attribute__ ((destructor)) _mdb_remove_backends()
|
||||||
{
|
{
|
||||||
g_hash_table_foreach_remove(mdb_backends, mdb_drop_backend, NULL);
|
g_hash_table_foreach_remove(mdb_backends, mdb_drop_backend, NULL);
|
||||||
g_hash_table_destroy(mdb_backends);
|
g_hash_table_destroy(mdb_backends);
|
||||||
|
|||||||
@@ -18,15 +18,6 @@
|
|||||||
|
|
||||||
#include "mdbtools.h"
|
#include "mdbtools.h"
|
||||||
|
|
||||||
void __attribute__ ((constructor)) _mdb_init()
|
|
||||||
{
|
|
||||||
mdb_init_backends();
|
|
||||||
}
|
|
||||||
void __attribute__ ((destructor)) _mdb_exit()
|
|
||||||
{
|
|
||||||
mdb_remove_backends();
|
|
||||||
}
|
|
||||||
|
|
||||||
void __attribute__((deprecated)) mdb_init()
|
void __attribute__((deprecated)) mdb_init()
|
||||||
{
|
{
|
||||||
fprintf(stderr, "mdb_init() is DEPRECATED and does nothing. Stop calling it.\n");
|
fprintf(stderr, "mdb_init() is DEPRECATED and does nothing. Stop calling it.\n");
|
||||||
|
|||||||
Reference in New Issue
Block a user