;;;; *************************************************************************
;;;; FILE IDENTIFICATION
;;;;
-;;;; Name: clsql.system
-;;;; Purpose: Defsystem-3/4 for CLSQL
-;;;; Programmer: Kevin M. Rosenberg
-;;;; Date Started: Feb 2002
+;;;; Name: clsql.asd
+;;;; Purpose: System definition for CLSQL-CLASSIC
+;;;; Authors: Marcus Pearce and Kevin M. Rosenberg
+;;;; Created: March 2004
;;;;
-;;;; $Id: clsql.asd,v 1.8 2002/09/18 07:50:01 kevin Exp $
-;;;;
-;;;; This file, part of CLSQL, is Copyright (c) 2002 by Kevin M. Rosenberg
+;;;; $Id$
;;;;
;;;; CLSQL users are granted the rights to distribute and use this software
;;;; as governed by the terms of the Lisp Lesser GNU Public License
;;;; (http://opensource.franz.com/preamble.html), also known as the LLGPL.
;;;; *************************************************************************
-(in-package :asdf)
+(in-package #:cl-user)
+(defpackage #:clsql-system (:use #:asdf #:cl))
+(in-package #:clsql-system)
-(defsystem clsql
- :perform (load-op :after (op clsql)
- (pushnew :clsql cl:*features*))
- :components
- ((:module :sql
- :components
- ((:file "package")
- (:file "pool" :depends-on ("package"))
- (:file "loop-extension")
- (:file "sql" :depends-on ("pool"))
- (:file "transactions" :depends-on ("sql"))
- (:file "functional" :depends-on ("sql"))
- (:file "usql" :depends-on ("sql")))))
- :depends-on (:clsql-base)
- )
+(defsystem #:clsql
+ :name "CLSQL"
+ :author ""
+ :maintainer ""
+ :version ""
+ :licence ""
+ :description "A high level Common Lisp interface to SQL RDBMS."
+ :long-description "A high level Common Lisp interface to SQL RDBMS
+based on the Xanalys CommonSQL interface for Lispworks. It depends on
+the low-level database interfaces provided by CLSQL and includes both
+a functional and an object oriented interface."
+ :depends-on (clsql-base)
+ :components
+ ((:module sql
+ :components
+ ((:module :package
+ :pathname ""
+ :components ((:file "package")
+ (:file "kmr-mop" :depends-on ("package"))))
+ (:module :core
+ :pathname ""
+ :components ((:file "generics")
+ (:file "classes" :depends-on ("generics"))
+ (:file "operations" :depends-on ("classes"))
+ (:file "syntax" :depends-on ("operations")))
+ :depends-on (:package))
+ (:module :functional
+ :pathname ""
+ :components ((:file "sql")
+ (:file "table" :depends-on ("sql")))
+ :depends-on (:core))
+ (:module :object
+ :pathname ""
+ :components ((:file "metaclasses")
+ (:file "objects" :depends-on ("metaclasses"))
+ (:file "relations" :depends-on ("objects")))
+ :depends-on (:functional))))))
+
-(defmethod source-file-type ((c cl-source-file)
-e (s (eql (find-system :clsql))))
- "cl")
+(defmethod perform ((o test-op) (c (eql (find-system 'clsql))))
+ (operate 'load-op 'clsql-tests)
+ (operate 'test-op 'clsql-tests :force t))