X-Git-Url: https://git.distorted.org.uk/~mdw/sod/blobdiff_plain/c2438e62e7c3cf1b7006522cef61e8c6f797600b..b7fcf94152e4c1938fbca55d13b1e6a64b694bd6:/src/builtin.lisp diff --git a/src/builtin.lisp b/src/builtin.lisp index 696bcf6..fbef93b 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 @@ -85,6 +85,9 @@ (define-class-slot "initsz" (class) size-t (format nil "sizeof(struct ~A)" (ilayout-struct-tag class))) +(define-class-slot "align" (class) size-t + (format nil "SOD__ALIGNOF(struct ~A)" (ilayout-struct-tag class))) + (define-class-slot "imprint" (class stream) (* (fun (* void) ("/*p*/" (* void)))) (format nil "~A__imprint" class) @@ -140,19 +143,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 +320,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 +339,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 --------------------------------------------------