X-Git-Url: https://git.distorted.org.uk/~mdw/sod/blobdiff_plain/c2438e62e7c3cf1b7006522cef61e8c6f797600b..7de8c6661211bce3a2b2739b461f33a370294979:/src/builtin.lisp diff --git a/src/builtin.lisp b/src/builtin.lisp index 696bcf6..ea72d66 100644 --- a/src/builtin.lisp +++ b/src/builtin.lisp @@ -7,7 +7,7 @@ ;;;----- Licensing notice --------------------------------------------------- ;;; -;;; This file is part of the Sensble Object Design, an object system for C. +;;; This file is part of the Sensible Object Design, an object system for C. ;;; ;;; SOD is free software; you can redistribute it and/or modify ;;; it under the terms of the GNU General Public License as published by @@ -90,8 +90,8 @@ (format nil "~A__imprint" class) (let ((ilayout (sod-class-ilayout class))) (format stream "~&~: -/* Imprint raw memory with instance structure. */ -static void *~A__imprint(void *p) +/* Imprint raw memory with class `~A' instance structure. */ +static void *~:*~A__imprint(void *p) { struct ~A *sod__obj = p; @@ -140,19 +140,23 @@ static void *~A__init(void *p)~%{~%" class) " struct ~A *sod__obj = ~A__imprint(p);~2%" (ilayout-struct-tag class) class) (setf used t)) - (format stream " ~A.~A =" isl - (sod-slot-name dslot)) + (format stream " {~% ") + (pprint-c-type (sod-slot-type dslot) stream + *sod-tmp-val*) + (format stream " =") (ecase (sod-initializer-value-kind init) (:simple (write (sod-initializer-value-form init) :stream stream :pretty nil :escape nil) (format stream ";~%")) - (:compound (format stream " (~A) {" - (sod-slot-type dslot)) + (:compound (format stream " {") (write (sod-initializer-value-form init) :stream stream :pretty nil :escape nil) - (format stream "};~%")))))))))))) + (format stream " };~%"))) + (format stream " ~A.~A = ~A;~% }~%" + isl (sod-slot-name dslot) + *sod-tmp-val*)))))))))) (unless used (format stream " ~A__imprint(p);~%" class)) (format stream "~&~: @@ -313,7 +317,7 @@ static const SodClass *const ~A__cpl[] = { :case :common) :state nil))) (with-module-environment (module) - (dolist (name '("va_list" "size_t" "ptrdiff_t")) + (dolist (name '("va_list" "size_t" "ptrdiff_t" "wchar_t")) (add-to-module module (make-instance 'type-item :name name))) (flet ((header-name (name) (concatenate 'string "\"" (string-downcase name) ".h\"")) @@ -332,4 +336,7 @@ static const SodClass *const ~A__cpl[] = { (bootstrap-classes module)) (setf *builtin-module* module))) +(define-clear-the-decks builtin-module + (unless *builtin-module* (make-builtin-module))) + ;;;----- That's all, folks --------------------------------------------------