1 ;;;; -*- Mode: LISP; Syntax: ANSI-Common-Lisp; Base: 10 -*-
2 ;;;; *************************************************************************
3 ;;;; FILE IDENTIFICATION
5 ;;;; Name: package.lisp
6 ;;;; Purpose: Package definition for SQL interface
8 ;;;; This file is part of CLSQL.
10 ;;;; CLSQL users are granted the rights to distribute and use this software
11 ;;;; as governed by the terms of the Lisp Lesser GNU Public License
12 ;;;; (http://opensource.franz.com/preamble.html), also known as the LLGPL.
13 ;;;; *************************************************************************
15 (in-package #:cl-user)
17 ;;;; This file makes the required package definitions for CLSQL's
20 (eval-when (:compile-toplevel :load-toplevel :execute)
22 (if (find-package 'sb-mop)
23 (pushnew :clsql-sbcl-mop cl:*features*)
24 (pushnew :clsql-sbcl-pcl cl:*features*))
27 (if (eq (symbol-package 'pcl:find-class)
28 (find-package 'common-lisp))
29 (pushnew :clsql-cmucl-mop cl:*features*)
30 (pushnew :clsql-cmucl-pcl cl:*features*)))
33 (eval-when (:compile-toplevel :load-toplevel :execute)
34 (defpackage #:clsql-sys
36 #+clsql-sbcl-mop #:sb-mop
37 #+clsql-cmucl-mop #:mop
41 #+openmcl #:openmcl-mop)
44 (:shadowing-import-from
47 (:shadowing-import-from
50 (:shadowing-import-from
52 #:generic-function-lambda-list)
54 (:shadowing-import-from
58 #:class-of #:class-name #:class-slots #:find-class
61 #:slot-definition-name #:finalize-inheritance
62 #:standard-direct-slot-definition
63 #:standard-effective-slot-definition #:validate-superclass
64 #:direct-slot-definition-class #:compute-effective-slot-definition
65 #:effective-slot-definition-class
66 #:slot-value-using-class
67 #:class-prototype #:generic-function-method-class #:intern-eql-specializer
68 #:make-method-lambda #:generic-function-lambda-list
69 #:class-precedence-list #:slot-definition-type
70 #:class-direct-superclasses
71 #:compute-class-precedence-list)
73 (:shadowing-import-from
75 #:generic-function-lambda-list)
77 (:shadowing-import-from
81 #:class-of #:class-name #:class-slots #:find-class #:standard-class
83 #:slot-definition-name #:finalize-inheritance
84 #:standard-direct-slot-definition #:standard-effective-slot-definition
85 #:validate-superclass #:direct-slot-definition-class
86 #:effective-slot-definition-class
87 #:compute-effective-slot-definition
88 #:slot-value-using-class
89 #:class-prototype #:generic-function-method-class #:intern-eql-specializer
90 #:make-method-lambda #:generic-function-lambda-list
91 #:class-precedence-list #:slot-definition-type
92 #:class-direct-superclasses
93 #:compute-class-precedence-list)
95 (:shadowing-import-from
97 #:class-prototype ;; note: make-method-lambda is not fbound
101 ;; "Private" exports for use by interface packages
102 #:check-connection-spec
103 #:database-initialize-database-type
104 #:database-type-load-foreign
105 #:database-name-from-spec
107 #:database-disconnect
109 #:database-execute-command
110 #:database-create-sequence
111 #:database-drop-sequence
112 #:database-sequence-next
113 #:database-set-sequence-position
114 #:database-query-result-set
115 #:database-dump-result-set
116 #:database-store-next-row
117 #:database-list-tables
118 #:database-table-exists-p
119 #:database-list-views
120 #:database-view-exists-p
121 #:database-list-indexes
122 #:database-list-table-indexes
123 #:database-index-exists-p
124 #:database-list-sequences
125 #:database-sequence-last
126 #:database-sequence-exists-p
127 #:database-list-attributes
128 #:database-attribute-type
129 #:database-describe-table
130 #:database-type-library-loaded
136 #:db-backend-has-create/destroy-db?
138 #:db-type-has-bigint?
140 #:db-type-has-subqueries?
141 #:db-type-has-boolean-where?
142 #:db-type-transaction-capable?
143 #:db-type-has-fancy-math?
144 #:db-type-default-case
145 #:db-type-use-column-on-drop-index?
146 #:database-underlying-type
147 #:database-get-type-specifier
149 #:database-output-sql-as-type
152 #:database-create-large-object
153 #:database-write-large-object
154 #:database-read-large-object
155 #:database-delete-large-object
156 #:create-large-object
159 #:delete-large-object
161 ;; accessors for database class
167 #:command-recording-stream
168 #:result-recording-stream
180 #:symbol-name-default-case
181 #:convert-to-db-default-case
185 #:*loaded-database-types*
186 #:reload-database-types
187 #:*connect-if-exists*
188 #:connected-databases
192 #:database-type ; database x
195 #:number-to-sql-string
196 #:float-to-sql-string
201 #:generic-postgresql-database
202 #:generic-odbc-database
205 ;; Shared exports for re-export by CLSQL package.
206 ;; I = Implemented, D = Documented
208 ;;====================================================
209 #1=(;;------------------------------------------------
211 ;;------------------------------------------------
213 #:select ; objects xx
214 #:cache-table-queries ;
215 #:*cache-table-queries-default* ;
216 #:delete-records ; sql xx
217 #:insert-records ; sql xx
218 #:update-records ; sql xx
219 #:execute-command ; sql xx
221 #:print-query ; sql xx
230 #:sql-database-data-error
231 #:sql-connection-error
232 #:sql-temporary-error
234 #:sql-error-secondary-error-id
235 #:sql-error-database-message
241 #:sql-database-warning
244 #:create-table ; table xx
245 #:drop-table ; table xx
246 #:list-tables ; table xx
247 #:table-exists-p ; table xx
248 #:list-attributes ; table xx
249 #:attribute-type ; table xx
250 #:list-attribute-types ; table xx
251 #:*cache-table-queries-default* ; table xx
252 #:create-view ; table xx
253 #:drop-view ; table xx
254 #:create-index ; table xx
255 #:drop-index ; table xx
258 #:standard-db-object ; objects xx
259 #:def-view-class ; objects xx
260 #:create-view-from-class ; objects xx
261 #:drop-view-from-class ; objects xx
263 #:instance-refreshed ; objects xx
264 #:update-objects-joins ; objects xx
265 #:*default-update-objects-max-len* ; objects xx
266 #:update-slot-from-record ; objects xx
267 #:update-instance-from-records ; objects xx
268 #:update-records-from-instance ; objects xx
269 #:update-record-from-slot ; objects xx
270 #:update-record-from-slots ; objects xx
271 #:list-classes ; objects xx
272 #:delete-instance-records ; objects xx
273 ;;Symbolic SQL Syntax
275 #:sql-expression ; syntax xx
276 #:sql-operation ; syntax xx
277 #:sql-operator ; syntax xx
278 #:disable-sql-reader-syntax ; syntax xx
279 #:enable-sql-reader-syntax ; syntax xx
280 #:locally-disable-sql-reader-syntax ; syntax xx
281 #:locally-enable-sql-reader-syntax ; syntax xx
282 #:restore-sql-reader-syntax-state ; syntax xx
285 #:list-views ; table xx
286 #:view-exists-p ; table xx
287 #:list-indexes ; table xx
288 #:list-table-indexes ; table xx
289 #:index-exists-p ; table xx
290 #:create-sequence ; table xx
291 #:drop-sequence ; table xx
292 #:list-sequences ; table xx
293 #:sequence-exists-p ; table xx
294 #:sequence-next ; table xx
295 #:sequence-last ; table xx
296 #:set-sequence-position ; table xx
298 #:view-table ; metaclass x
299 #:universal-time ; objects xx
302 #:*db-auto-sync* ; objects xx
308 #:clsql-simple-warning
310 ;;-----------------------------------------------
311 ;; Symbolic Sql Syntax
312 ;;-----------------------------------------------
377 #:duration-timestring
408 #:time-by-adding-duration
434 ;; recording.lisp -- SQL I/O Recording
437 #:add-sql-stream ; recording xx
438 #:delete-sql-stream ; recording xx
439 #:list-sql-streams ; recording xx
440 #:sql-recording-p ; recording xx
441 #:sql-stream ; recording xx
442 #:start-sql-recording ; recording xx
443 #:stop-sql-recording ; recording xx
445 ;; database.lisp -- Connection
446 #:*default-database-type* ; clsql-base xx
447 #:*default-database* ; classes xx
448 #:*initialized-database-types*
449 #:initialize-database-type
450 #:connect ; database xx
451 #:disconnect ; database xx
452 #:*connect-if-exists* ; database xx
453 #:connected-databases ; database xx
454 #:database ; database xx
455 #:database-name ; database xx
456 #:reconnect ; database
457 #:find-database ; database xx
458 #:status ; database xx
460 #:with-default-database
468 #:*backend-warning-behavior*
473 #:rollback-transaction
474 #:add-transaction-commit-hook
475 #:add-transaction-rollback-hook
476 #:commit ; transact xx
477 #:rollback ; transact xx
478 #:with-transaction ; transact xx .
479 #:start-transaction ; transact xx
480 #:in-transaction-p ; transact xx
481 #:database-start-transaction
482 #:database-abort-transaction
483 #:database-commit-transaction
487 (:documentation "This is the INTERNAL SQL-Interface package of CLSQL."))
492 (:import-from #:clsql-sys . #1#)
494 (:documentation "This is the user package with CLSQL symbols."))
496 (defpackage #:clsql-user
498 (:import-from #:clsql-sys . #1#)
500 (:documentation "This is the user package with CLSQL symbols."))
502 ;; This is from USQL's pcl-patch
503 #+(or clsql-sbcl-pcl clsql-cmucl-pcl)
505 ;; Note that this will no longer required for cmucl as of version 19a.
506 (in-package #+cmu :pcl #+sbcl :sb-pcl)
507 (defmacro pv-binding1 ((pv calls pv-table-symbol pv-parameters slot-vars)
509 `(pv-env (,pv ,calls ,pv-table-symbol ,pv-parameters)
510 (let (,@(mapcar #'(lambda (slot-var p) `(,slot-var (get-slots-or-nil ,p)))
511 slot-vars pv-parameters))
512 ,@(mapcar #'(lambda (slot-var) `(declare (ignorable ,slot-var))) slot-vars)
515 ;; see http://thread.gmane.org/gmane.lisp.lispworks.general/681
517 (setf *packages-for-warn-on-redefinition*
518 (delete "SQL" *packages-for-warn-on-redefinition* :test 'string=))
521 (if (find-package 'sb-mop)
522 (setq cl:*features* (delete :clsql-sbcl-mop cl:*features*))
523 (setq cl:*features* (delete :clsql-sbcl-pcl cl:*features*)))
526 (if (find-package 'mop)
527 (setq cl:*features* (delete :clsql-cmucl-mop cl:*features*))
528 (setq cl:*features* (delete :clsql-cmucl-pcl cl:*features*)))