aboutsummaryrefslogtreecommitdiff
path: root/src/interfaces/python/pgsqldb.py
blob: df768b68b2f21be8dc2571f5d91e6b5c17b53664 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# pgsqldb.py
# Written by D'Arcy J.M. Cain

# This library implements the DB-SIG API
# It includes the pg module and builds on it

from _pg import *

import string

class _cursor:
	"""For cursor object"""

	def __init__(self, conn):
		self.conn = conn
		self.cursor = None
		self.arraysize = 1
		self.description = None
		self.name = string.split(`self`)[3][:-1]

	def close(self):
		if self.conn == None: raise self.conn.error, "Cursor has been closed"
		if self.cursor == None: raise self.conn.error, "No cursor created"
		self.conn.query('CLOSE %s' % self.name)
		self.conn = None

	def __del__(self):
		if self.cursor != None and self.conn != None:
			self.conn.query('CLOSE %s' % self.name)

	
class pgsqldb:
	"""This class wraps the pg connection type in a DB-SIG API interface"""

	def __init__(self, *args, **kw):
		self.db = apply(connect, args, kw)

		# Create convience methods, in a way that is still overridable.
		for e in ('query', 'reset', 'close', 'getnotify', 'inserttable',
						'putline', 'getline', 'endcopy',
						'host', 'port', 'db', 'options',
						'tty', 'error', 'status', 'user',
						'locreate', 'getlo', 'loimport'):
			if not hasattr(self,e) and hasattr(self.db,e):
				exec 'self.%s = self.db.%s' % ( e, e )