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-list-tables-and-sequences
119 #:database-table-exists-p
120 #:database-list-views
121 #:database-view-exists-p
122 #:database-list-indexes
123 #:database-list-table-indexes
124 #:database-index-exists-p
125 #:database-list-sequences
126 #:database-sequence-last
127 #:database-sequence-exists-p
128 #:database-list-attributes
129 #:database-attribute-type
130 #:database-describe-table
131 #:database-type-library-loaded
137 #:db-backend-has-create/destroy-db?
139 #:db-type-has-bigint?
141 #:db-type-has-subqueries?
142 #:db-type-has-boolean-where?
143 #:db-type-transaction-capable?
144 #:db-type-has-fancy-math?
145 #:db-type-default-case
146 #:db-type-use-column-on-drop-index?
147 #:database-underlying-type
148 #:database-get-type-specifier
150 #:database-output-sql-as-type
153 #:database-create-large-object
154 #:database-write-large-object
155 #:database-read-large-object
156 #:database-delete-large-object
157 #:create-large-object
160 #:delete-large-object
162 ;; accessors for database class
168 #:command-recording-stream
169 #:result-recording-stream
181 #:symbol-name-default-case
182 #:convert-to-db-default-case
186 #:*loaded-database-types*
187 #:reload-database-types
188 #:*connect-if-exists*
189 #:connected-databases
193 #:database-type ; database x
196 #:number-to-sql-string
197 #:float-to-sql-string
202 #:generic-postgresql-database
203 #:generic-odbc-database
206 ;; Shared exports for re-export by CLSQL package.
207 ;; I = Implemented, D = Documented
209 ;;====================================================
210 #1=(;;------------------------------------------------
212 ;;------------------------------------------------
214 #:select ; objects xx
215 #:cache-table-queries ;
216 #:*cache-table-queries-default* ;
217 #:delete-records ; sql xx
218 #:insert-records ; sql xx
219 #:update-records ; sql xx
220 #:execute-command ; sql xx
222 #:print-query ; sql xx
231 #:sql-database-data-error
232 #:sql-connection-error
233 #:sql-temporary-error
235 #:sql-error-secondary-error-id
236 #:sql-error-database-message
242 #:sql-database-warning
245 #:create-table ; table xx
246 #:drop-table ; table xx
247 #:list-tables ; table xx
248 #:table-exists-p ; table xx
249 #:list-attributes ; table xx
250 #:attribute-type ; table xx
251 #:list-attribute-types ; table xx
252 #:*cache-table-queries-default* ; table xx
253 #:create-view ; table xx
254 #:drop-view ; table xx
255 #:create-index ; table xx
256 #:drop-index ; table xx
259 #:standard-db-object ; objects xx
260 #:def-view-class ; objects xx
261 #:create-view-from-class ; objects xx
262 #:drop-view-from-class ; objects xx
264 #:instance-refreshed ; objects xx
265 #:update-objects-joins ; objects xx
266 #:*default-update-objects-max-len* ; objects xx
267 #:update-slot-from-record ; objects xx
268 #:update-instance-from-records ; objects xx
269 #:update-records-from-instance ; objects xx
270 #:update-record-from-slot ; objects xx
271 #:update-record-from-slots ; objects xx
272 #:list-classes ; objects xx
273 #:delete-instance-records ; objects xx
274 ;;Symbolic SQL Syntax
276 #:sql-expression ; syntax xx
277 #:sql-operation ; syntax xx
278 #:sql-operator ; syntax xx
279 #:disable-sql-reader-syntax ; syntax xx
280 #:enable-sql-reader-syntax ; syntax xx
281 #:locally-disable-sql-reader-syntax ; syntax xx
282 #:locally-enable-sql-reader-syntax ; syntax xx
283 #:restore-sql-reader-syntax-state ; syntax xx
286 #:list-views ; table xx
287 #:view-exists-p ; table xx
288 #:list-indexes ; table xx
289 #:list-table-indexes ; table xx
290 #:index-exists-p ; table xx
291 #:create-sequence ; table xx
292 #:drop-sequence ; table xx
293 #:list-sequences ; table xx
294 #:sequence-exists-p ; table xx
295 #:sequence-next ; table xx
296 #:sequence-last ; table xx
297 #:set-sequence-position ; table xx
299 #:view-table ; metaclass x
300 #:universal-time ; objects xx
303 #:*db-auto-sync* ; objects xx
309 #:clsql-simple-warning
311 ;;-----------------------------------------------
312 ;; Symbolic Sql Syntax
313 ;;-----------------------------------------------
378 #:duration-timestring
409 #:time-by-adding-duration
435 ;; recording.lisp -- SQL I/O Recording
438 #:add-sql-stream ; recording xx
439 #:delete-sql-stream ; recording xx
440 #:list-sql-streams ; recording xx
441 #:sql-recording-p ; recording xx
442 #:sql-stream ; recording xx
443 #:start-sql-recording ; recording xx
444 #:stop-sql-recording ; recording xx
446 ;; database.lisp -- Connection
447 #:*default-database-type* ; clsql-base xx
448 #:*default-database* ; classes xx
449 #:*initialized-database-types*
450 #:initialize-database-type
451 #:connect ; database xx
452 #:disconnect ; database xx
453 #:*connect-if-exists* ; database xx
454 #:connected-databases ; database xx
455 #:database ; database xx
456 #:database-name ; database xx
457 #:reconnect ; database
458 #:find-database ; database xx
459 #:status ; database xx
461 #:with-default-database
469 #:*backend-warning-behavior*
474 #:rollback-transaction
475 #:add-transaction-commit-hook
476 #:add-transaction-rollback-hook
477 #:commit ; transact xx
478 #:rollback ; transact xx
479 #:with-transaction ; transact xx .
480 #:start-transaction ; transact xx
481 #:in-transaction-p ; transact xx
482 #:database-start-transaction
483 #:database-abort-transaction
484 #:database-commit-transaction
488 (:documentation "This is the INTERNAL SQL-Interface package of CLSQL."))
493 (:import-from #:clsql-sys . #1#)
495 (:documentation "This is the user package with CLSQL symbols."))
497 (defpackage #:clsql-user
499 (:import-from #:clsql-sys . #1#)
501 (:documentation "This is the user package with CLSQL symbols."))
503 ;; This is from USQL's pcl-patch
504 #+(or clsql-sbcl-pcl clsql-cmucl-pcl)
506 ;; Note that this will no longer required for cmucl as of version 19a.
507 (in-package #+cmu :pcl #+sbcl :sb-pcl)
508 (defmacro pv-binding1 ((pv calls pv-table-symbol pv-parameters slot-vars)
510 `(pv-env (,pv ,calls ,pv-table-symbol ,pv-parameters)
511 (let (,@(mapcar #'(lambda (slot-var p) `(,slot-var (get-slots-or-nil ,p)))
512 slot-vars pv-parameters))
513 ,@(mapcar #'(lambda (slot-var) `(declare (ignorable ,slot-var))) slot-vars)
516 ;; see http://thread.gmane.org/gmane.lisp.lispworks.general/681
518 (setf *packages-for-warn-on-redefinition*
519 (delete "SQL" *packages-for-warn-on-redefinition* :test 'string=))
522 (if (find-package 'sb-mop)
523 (setq cl:*features* (delete :clsql-sbcl-mop cl:*features*))
524 (setq cl:*features* (delete :clsql-sbcl-pcl cl:*features*)))
527 (if (find-package 'mop)
528 (setq cl:*features* (delete :clsql-cmucl-mop cl:*features*))
529 (setq cl:*features* (delete :clsql-cmucl-pcl cl:*features*)))