mirror of
https://github.com/python/cpython.git
synced 2024-12-12 03:04:15 +08:00
c95f554a40
Introduce the autocommit attribute to Connection and the autocommit parameter to connect() for PEP 249-compliant transaction handling. Co-authored-by: Alex Waygood <Alex.Waygood@Gmail.com> Co-authored-by: C.A.M. Gerlach <CAM.Gerlach@Gerlach.CAM> Co-authored-by: Géry Ogam <gery.ogam@gmail.com>
100 lines
2.9 KiB
C
100 lines
2.9 KiB
C
/* module.h - definitions for the module
|
|
*
|
|
* Copyright (C) 2004-2010 Gerhard Häring <gh@ghaering.de>
|
|
*
|
|
* This file is part of pysqlite.
|
|
*
|
|
* This software is provided 'as-is', without any express or implied
|
|
* warranty. In no event will the authors be held liable for any damages
|
|
* arising from the use of this software.
|
|
*
|
|
* Permission is granted to anyone to use this software for any purpose,
|
|
* including commercial applications, and to alter it and redistribute it
|
|
* freely, subject to the following restrictions:
|
|
*
|
|
* 1. The origin of this software must not be misrepresented; you must not
|
|
* claim that you wrote the original software. If you use this software
|
|
* in a product, an acknowledgment in the product documentation would be
|
|
* appreciated but is not required.
|
|
* 2. Altered source versions must be plainly marked as such, and must not be
|
|
* misrepresented as being the original software.
|
|
* 3. This notice may not be removed or altered from any source distribution.
|
|
*/
|
|
|
|
#ifndef PYSQLITE_MODULE_H
|
|
#define PYSQLITE_MODULE_H
|
|
#define PY_SSIZE_T_CLEAN
|
|
#include "Python.h"
|
|
|
|
#define LEGACY_TRANSACTION_CONTROL -1
|
|
|
|
#define PYSQLITE_VERSION "2.6.0"
|
|
#define MODULE_NAME "sqlite3"
|
|
|
|
typedef struct {
|
|
PyObject *DataError;
|
|
PyObject *DatabaseError;
|
|
PyObject *Error;
|
|
PyObject *IntegrityError;
|
|
PyObject *InterfaceError;
|
|
PyObject *InternalError;
|
|
PyObject *NotSupportedError;
|
|
PyObject *OperationalError;
|
|
PyObject *ProgrammingError;
|
|
PyObject *Warning;
|
|
|
|
|
|
/* A dictionary, mapping column types (INTEGER, VARCHAR, etc.) to converter
|
|
* functions, that convert the SQL value to the appropriate Python value.
|
|
* The key is uppercase.
|
|
*/
|
|
PyObject *converters;
|
|
|
|
PyObject *lru_cache;
|
|
PyObject *psyco_adapters; // The adapters registry
|
|
int BaseTypeAdapted;
|
|
int enable_callback_tracebacks;
|
|
|
|
PyTypeObject *BlobType;
|
|
PyTypeObject *ConnectionType;
|
|
PyTypeObject *CursorType;
|
|
PyTypeObject *PrepareProtocolType;
|
|
PyTypeObject *RowType;
|
|
PyTypeObject *StatementType;
|
|
|
|
/* Pointers to interned strings */
|
|
PyObject *str___adapt__;
|
|
PyObject *str___conform__;
|
|
PyObject *str_executescript;
|
|
PyObject *str_finalize;
|
|
PyObject *str_inverse;
|
|
PyObject *str_step;
|
|
PyObject *str_upper;
|
|
PyObject *str_value;
|
|
} pysqlite_state;
|
|
|
|
extern pysqlite_state pysqlite_global_state;
|
|
|
|
static inline pysqlite_state *
|
|
pysqlite_get_state(PyObject *module)
|
|
{
|
|
pysqlite_state *state = (pysqlite_state *)PyModule_GetState(module);
|
|
assert(state != NULL);
|
|
return state;
|
|
}
|
|
|
|
extern struct PyModuleDef _sqlite3module;
|
|
static inline pysqlite_state *
|
|
pysqlite_get_state_by_type(PyTypeObject *tp)
|
|
{
|
|
PyObject *module = PyType_GetModuleByDef(tp, &_sqlite3module);
|
|
assert(module != NULL);
|
|
return pysqlite_get_state(module);
|
|
}
|
|
|
|
extern const char *pysqlite_error_name(int rc);
|
|
|
|
#define PARSE_DECLTYPES 1
|
|
#define PARSE_COLNAMES 2
|
|
#endif
|