extern.h
来自「PostgreSQL7.4.6 for Linux」· C头文件 代码 · 共 137 行
H
137 行
#ifndef _ECPG_LIB_EXTERN_H#define _ECPG_LIB_EXTERN_H#include "postgres_fe.h"#include "libpq-fe.h"#include "sqlca.h"enum COMPAT_MODE{ ECPG_COMPAT_PGSQL = 0, ECPG_COMPAT_INFORMIX, ECPG_COMPAT_INFORMIX_SE};#define INFORMIX_MODE(X) ((X) == ECPG_COMPAT_INFORMIX || (X) == ECPG_COMPAT_INFORMIX_SE)enum ARRAY_TYPE{ ECPG_ARRAY_NOT_SET, ECPG_ARRAY_ARRAY, ECPG_ARRAY_VECTOR, ECPG_ARRAY_NONE};/* Here are some methods used by the lib. *//* Returns a pointer to a string containing a simple type name. */void ECPGadd_mem(void *ptr, int lineno);bool ECPGget_data(const PGresult *, int, int, int, enum ECPGttype type, enum ECPGttype, char *, char *, long, long, long, enum ARRAY_TYPE, enum COMPAT_MODE, bool);struct connection *ECPGget_connection(const char *);char *ECPGalloc(long, int);char *ECPGrealloc(void *, long, int);void ECPGfree(void *);bool ECPGinit(const struct connection *, const char *, const int);char *ECPGstrdup(const char *, int);const char *ECPGtype_name(enum ECPGttype);unsigned int ECPGDynamicType(Oid);void ECPGfree_auto_mem(void);void ECPGclear_auto_mem(void);/* A generic varchar type. */struct ECPGgeneric_varchar{ int len; char arr[1];};/* * type information cache */struct ECPGtype_information_cache{ struct ECPGtype_information_cache *next; int oid; bool isarray;};/* structure to store one statement */struct statement{ int lineno; char *command; struct connection *connection; enum COMPAT_MODE compat; bool force_indicator; struct variable *inlist; struct variable *outlist;};/* structure to store connections */struct connection{ char *name; PGconn *connection; bool committed; int autocommit; struct ECPGtype_information_cache *cache_head; struct connection *next;};/* structure to store descriptors */struct descriptor{ char *name; PGresult *result; struct descriptor *next;};struct variable{ enum ECPGttype type; void *value; void *pointer; long varcharsize; long arrsize; long offset; enum ECPGttype ind_type; void *ind_value; void *ind_pointer; long ind_varcharsize; long ind_arrsize; long ind_offset; struct variable *next;};PGresult ** ECPGdescriptor_lvalue(int line, const char *descriptor);bool ECPGstore_result(const PGresult *results, int act_field, const struct statement * stmt, struct variable * var);/* SQLSTATE values generated or processed by ecpglib (intentionally * not exported -- users should refer to the codes directly) */#define ECPG_SQLSTATE_NO_DATA "02000"#define ECPG_SQLSTATE_USING_CLAUSE_DOES_NOT_MATCH_PARAMETERS "07001"#define ECPG_SQLSTATE_USING_CLAUSE_DOES_NOT_MATCH_TARGETS "07002"#define ECPG_SQLSTATE_RESTRICTED_DATA_TYPE_ATTRIBUTE_VIOLATION "07006"#define ECPG_SQLSTATE_INVALID_DESCRIPTOR_INDEX "07009"#define ECPG_SQLSTATE_SQLCLIENT_UNABLE_TO_ESTABLISH_SQLCONNECTION "08001"#define ECPG_SQLSTATE_CONNECTION_DOES_NOT_EXIST "08003"#define ECPG_SQLSTATE_TRANSACTION_RESOLUTION_UNKNOWN "08007"#define ECPG_SQLSTATE_CARDINALITY_VIOLATION "21000"#define ECPG_SQLSTATE_NULL_VALUE_NO_INDICATOR_PARAMETER "22002"#define ECPG_SQLSTATE_ACTIVE_SQL_TRANSACTION "25001"#define ECPG_SQLSTATE_NO_ACTIVE_SQL_TRANSACTION "25P01"#define ECPG_SQLSTATE_INVALID_SQL_STATEMENT_NAME "26000"#define ECPG_SQLSTATE_INVALID_SQL_DESCRIPTOR_NAME "33000"#define ECPG_SQLSTATE_INVALID_CURSOR_NAME "34000"#define ECPG_SQLSTATE_SYNTAX_ERROR "42601"#define ECPG_SQLSTATE_DATATYPE_MISMATCH "42804"#define ECPG_SQLSTATE_DUPLICATE_CURSOR "42P03"/* implementation-defined internal errors of ecpg */#define ECPG_SQLSTATE_ECPG_INTERNAL_ERROR "YE000"#define ECPG_SQLSTATE_ECPG_OUT_OF_MEMORY "YE001"#endif /* _ECPG_LIB_EXTERN_H */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?