Skip to content
oct.system 2.67 KiB
Newer Older
;;;; -*- Mode: lisp -*-
;;;;
;;;; Copyright (c) 2007 Raymond Toy
;;;;
;;;; Permission is hereby granted, free of charge, to any person
;;;; obtaining a copy of this software and associated documentation
;;;; files (the "Software"), to deal in the Software without
;;;; restriction, including without limitation the rights to use,
;;;; copy, modify, merge, publish, distribute, sublicense, and/or sell
;;;; copies of the Software, and to permit persons to whom the
;;;; Software is furnished to do so, subject to the following
;;;; conditions:
;;;;
;;;; The above copyright notice and this permission notice shall be
;;;; included in all copies or substantial portions of the Software.
;;;;
;;;; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
;;;; EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
;;;; OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
;;;; NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
;;;; HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
;;;; WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
;;;; FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
;;;; OTHER DEALINGS IN THE SOFTWARE.
toy's avatar
toy committed

;; If you want all core functions to be inline (like the C++ code
;; does), add :qd-inline to *features* by enabling the following line.
;; This makes compilation much, much slower, but the resulting code
;; conses much less and is significantly faster.
(eval-when (:load-toplevel :compile-toplevel :execute)
  (pushnew :qd-inline *features*))

toy's avatar
toy committed
;; To be able to inline all the functions, we need to make
;; *inline-expansion-limit* much larger.
;;
;; Not sure we really want to inline everything, but the QD C++ code
;; inlines all of the functions so we do the same.  This makes CMUCL
;; take a very long time to compile the code, and the resulting
;; functions are huge.  (I think div-qd is 8 KB, and sqrt-qd is a
;; whopping 30 KB!)
;;
toy's avatar
toy committed
(eval-when (:load-toplevel :compile-toplevel :execute)
toy's avatar
toy committed
  (setf ext:*inline-expansion-limit* 1600))
toy's avatar
toy committed

(mk:defsystem oct
toy's avatar
toy committed
  :source-pathname (make-pathname :directory (pathname-directory *load-pathname*))
  :components
  ((:file "qd-package")
   (:file "qd-rep" :depends-on ("qd-package"))
Raymond Toy's avatar
Raymond Toy committed
   (:file "qd-dd" :depends-on ("qd-package" "qd-rep"))
toy's avatar
toy committed
   (:file "qd"
Raymond Toy's avatar
Raymond Toy committed
	  :depends-on ("qd-rep" #-cmu "qd-dd"))
   (:file "qd-io"
	  :depends-on ("qd"))
toy's avatar
toy committed
   (:file "qd-const"
toy's avatar
toy committed
	  :depends-on ("qd-io"))
toy's avatar
toy committed
   (:file "qd-fun"
toy's avatar
toy committed
	  :depends-on ("qd" "qd-const"))
   (:file "qd-class"
toy's avatar
toy committed
	  :depends-on ("qd-fun"))
   (:file "qd-methods"
toy's avatar
toy committed
	  :depends-on ("qd-class"))
   (:file "qd-format"
toy's avatar
toy committed
	  :depends-on ("qd-methods"))
   (:file "qd-complex"
	  :depends-on ("qd-methods"))
   ))