DB-API: moved from github:gramps-project/addons-source

This commit is contained in:
Doug Blank 2016-01-26 18:07:12 -05:00
parent 64a3b6570d
commit 2cf95cd866
7 changed files with 1886 additions and 0 deletions

View File

@ -0,0 +1,33 @@
#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2015 Douglas Blank <doug.blank@gmail.com>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
#
register(DATABASE,
id = 'dbapi',
name = _("DB-API 2.0 Database Backend"),
name_accell = _("DB-_API 2.0 Database Backend"),
description = _("DB-API 2.0 Database Backend"),
version = '1.0.32',
gramps_target_version = "5.0",
status = STABLE,
fname = 'dbapi.py',
databaseclass = 'DBAPI',
authors=['Doug Blank'],
authors_email=["doug.blank@gmail.com"],
)

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,25 @@
## ----------------------------------------------
## Postgresql
## ----------------------------------------------
#from dbapi_support.postgresql import Postgresql
#dbapi = Postgresql(dbname='mydb', user='postgres',
# host='localhost', password='PASSWORD')
## ----------------------------------------------
## MySQL
## ----------------------------------------------
#from dbapi_support.mysql import MySQL
#dbapi = MySQL("localhost", "root", "PASSWORD", "mysqldb",
# charset='utf8', use_unicode=True)
## ----------------------------------------------
## Sqlite
## ----------------------------------------------
from dbapi_support.sqlite import Sqlite
path_to_db = os.path.join(os.path.dirname(os.path.realpath(__file__)),
'sqlite.db')
dbapi = Sqlite(path_to_db)

View File

@ -0,0 +1,37 @@
import MySQLdb
MySQLdb.paramstyle = 'qmark' ## Doesn't work
class MySQL(object):
def __init__(self, *args, **kwargs):
self.connection = MySQLdb.connect(*args, **kwargs)
def execute(self, query, args=[]):
## Workaround: no qmark support
query = query.replace("?", "%s")
self.cursor = self.connection.cursor()
self.cursor.execute(query, args)
def fetchone(self):
return self.cursor.fetchone()
def fetchall(self):
return self.cursor.fetchall()
def commit(self):
self.connection.commit()
def rollback(self):
self.connection.rollback()
def try_execute(self, sql):
try:
cursor = self.connection.cursor()
cursor.execute(sql)
self.connection.commit()
except Exception as exc:
self.connection.rollback()
#print(str(exc))
def close(self):
self.connection.close()

View File

@ -0,0 +1,36 @@
import pg8000
pg8000.paramstyle = 'qmark'
class Postgresql(object):
def __init__(self, *args, **kwargs):
self.connection = pg8000.connect(*args, **kwargs)
def execute(self, *args, **kwargs):
self.cursor = self.connection.cursor()
self.cursor.execute(*args, **kwargs)
def fetchone(self):
return self.cursor.fetchone()
def fetchall(self):
return self.cursor.fetchall()
def commit(self):
self.connection.commit()
def rollback(self):
self.connection.rollback()
def try_execute(self, sql):
sql = sql.replace("BLOB", "bytea")
try:
cursor = self.connection.cursor()
cursor.execute(sql)
self.connection.commit()
except Exception as exc:
self.connection.rollback()
#print(str(exc))
def close(self):
self.connection.close()

View File

@ -0,0 +1,34 @@
import os
import sqlite3
sqlite3.paramstyle = 'qmark'
class Sqlite(object):
def __init__(self, *args, **kwargs):
self.connection = sqlite3.connect(*args, **kwargs)
self.queries = {}
def execute(self, *args, **kwargs):
self.cursor = self.connection.execute(*args, **kwargs)
def fetchone(self):
return self.cursor.fetchone()
def fetchall(self):
return self.cursor.fetchall()
def commit(self):
self.connection.commit()
def rollback(self):
self.connection.rollback()
def try_execute(self, sql):
try:
self.connection.execute(sql)
except Exception as exc:
#print(str(exc))
pass
def close(self):
self.connection.close()