;;; -*-lisp-*-
;;;
-;;; System definition for the Simple Object Design translator
+;;; System definition for the Sensible Object Design translator
;;;
;;; (c) 2009 Straylight/Edgeware
;;;
(defsystem sod
;; Boring copyright stuff.
- :version "1.0.0"
+ :version "0.1.0"
:author "Mark Wooding"
:license "GNU General Public License, version 2 or later"
:description "A Sensible Object Design for C."
:long-description
- "This system implements a fairly simple, yet powerful object system for
+ "This system implements a fairly simple, yet powerful, object system for
plain old C. Its main features are as follows.
* Multiple inheritance, done properly (unlike C++, say), with a
(:file "scanner-context-impl" :depends-on
("parser-proto" "scanner-proto"))))
- (:file "package" :depends-on ("parser"))
+ (:file "package" :depends-on ("utilities" "parser"))
+
+ ;; Lexical analysis.
+ (:file "lexer-proto" :depends-on ("package" "parser"))
+ (:file "lexer-impl" :depends-on ("lexer-proto"))
+ (:file "fragment-parse" :depends-on ("lexer-proto"))
;; C type representation protocol.
(:file "c-types-proto" :depends-on ("package"))
(:file "c-types-impl" :depends-on ("c-types-proto"))
+ (:file "c-types-parse" :depends-on
+ ("c-types-proto" "c-types-class-impl" "fragment-parse"))
;; Property set protocol.
(:file "pset-proto" :depends-on ("package"))
(:file "pset-impl" :depends-on ("pset-proto"))
- (:file "pset-parse" :depends-on ("pset-proto" "lexical-parse"))
-
- ;; Lexical analysis.
- (:file "lexical-parse" :depends-on ("parser"))
- (:file "fragment-parse" :depends-on ("lexical-parse"))
+ (:file "pset-parse" :depends-on ("pset-proto" "lexer-proto"))
;; Code generation protocol.
- (:file "codegen-proto" :depends-on ("package"))
+ (:file "codegen-proto" :depends-on ("module-proto"))
(:file "codegen-impl" :depends-on ("codegen-proto"))
;; Modules.
(:file "module-proto" :depends-on ("package"))
(:file "module-impl" :depends-on
("module-proto" "pset-proto" "c-types-class-impl" "builtin"))
- (:file "builtin" :depends-on ("module-proto" "pset-proto" "classes"
- "c-types-impl" "c-types-class-impl"))
- (:file "module-parse" :depends-on ("module-impl"
- "lexical-parse" "fragment-parse"))
+ (:file "builtin" :depends-on
+ ("module-proto" "pset-proto" "c-types-impl" "c-types-class-impl"
+ "classes" "class-layout-proto"))
+ (:file "module-parse" :depends-on
+ ("class-make-proto" "class-finalize-proto"
+ "fragment-parse" "lexer-proto" "module-impl"))
+ (:file "module-output" :depends-on ("module-impl" "output-proto"))
;; Output.
(:file "output-proto" :depends-on ("package"))
(:file "class-finalize-impl" :depends-on ("class-finalize-proto"))
;; Method generation.
- (:file "method-proto" :depends-on ("class-utilities"))
+ (:file "method-proto" :depends-on ("class-make-proto"))
(:file "method-impl" :depends-on ("method-proto"))
+ (:file "method-aggregate" :depends-on ("method-impl"))
;; Class output.
- (:file "class-output" :depends-on ("output-proto" "classes"))))
+ (:file "class-output" :depends-on
+ ("classes" "class-layout-impl" "method-impl" "output-proto"))
+
+ ;; Debugging and interactive testing.
+ (:file "debug" :depends-on ("builtin" "module-output"))))
;;;--------------------------------------------------------------------------
;;; Testing.
(defmethod perform ((op test-op) (component (eql (find-system "sod"))))
- (operate 'test-op "sod-test" :force t))
+ (declare (ignore op component))
+ (handler-bind (((or warning style-warning)
+ (lambda (cond)
+ (declare (ignore cond))
+ (invoke-restart 'muffle-warning))))
+ (operate 'test-op "sod-test")))
;;;----- That's all, folks --------------------------------------------------