~ chicken-core (chicken-5) 4b4931299261d47843374c1f500ab0040c1d43c1
commit 4b4931299261d47843374c1f500ab0040c1d43c1 Author: felix <felix@call-with-current-continuation.org> AuthorDate: Mon Sep 11 19:08:44 2017 +0200 Commit: Evan Hanson <evhan@foldling.org> CommitDate: Tue Sep 12 17:07:32 2017 +1200 Fix handling of types-file + inline-file Ensure paths to types- and inline-files are absolute, document optional filenames for types-file/inline-file egg properties, pass proper options to csc in these cases. Thanks to Kooda for pointing out these omissions. Signed-off-by: Evan Hanson <evhan@foldling.org> diff --git a/egg-compile.scm b/egg-compile.scm index 5ed16c46..ce931124 100644 --- a/egg-compile.scm +++ b/egg-compile.scm @@ -354,10 +354,17 @@ (append (if (memq 'dynamic link) (list (apply compile-dynamic-extension data)) '()) - ;; static must come last, as *.o file will be overwritten - ;; and removed by dynamic build (meh) (if (memq 'static link) - (list (apply compile-static-extension data)) + ;; if compiling both static + dynamic, override + ;; types-file: + inline-file: properties to + ;; avoid generating things twice: + (list (apply compile-static-extension + (if (memq 'dynamic link) + (cons (car data) + (append '(types-file: #f + inline-file: #f) + (cdr data))) + data))) '()) (if (uses-compiled-import-library? mode) (map (lambda (mod) @@ -417,16 +424,25 @@ ;;; shell code generation - build operations -(define ((compile-static-extension name #!key mode dependencies source - (options '()) custom) +(define ((compile-static-extension name #!key mode dependencies + source (options '()) + custom types-file inline-file) srcdir platform) (let* ((cmd (or (and custom (prefix-custom-command custom)) default-csc)) (sname (prefix srcdir name)) (ssname (and source (prefix srcdir source))) - (opts (if (null? options) - default-static-compilation-options - options)) + (opts (append (if (null? options) + default-static-compilation-options + options) + (if types-file + (list "-emit-type-file" + (quotearg (prefix srcdir (conc types-file ".types")))) + '()) + (if inline-file + (list "-emit-inline-file" + (quotearg (prefix srcdir (conc inline-file ".inline")))) + '()))) (out (quotearg (target-file (conc sname ".static" (object-extension platform)) @@ -446,14 +462,22 @@ (define ((compile-dynamic-extension name #!key mode dependencies mode source (options '()) (link-options '()) - custom) + custom types-file inline-file) srcdir platform) (let* ((cmd (or (and custom (prefix-custom-command custom)) default-csc)) (sname (prefix srcdir name)) - (opts (if (null? options) - default-dynamic-compilation-options - options)) + (opts (append (if (null? options) + default-dynamic-compilation-options + options) + (if types-file + (list "-emit-type-file" + (quotearg (prefix srcdir (conc types-file ".types")))) + '()) + (if inline-file + (list "-emit-inline-file" + (quotearg (prefix srcdir (conc inline-file ".inline")))) + '()))) (ssname (and source (prefix srcdir source))) (out (quotearg (target-file (conc sname ".so") mode))) (src (quotearg (or ssname (conc sname ".scm"))))) @@ -611,8 +635,7 @@ srcdir platform) (let* ((cmd (install-file-command platform)) (mkdir (mkdir-command platform)) - (sname (prefix srcdir name)) - (out (quotearg (conc types-file ".types"))) + (out (quotearg (prefix srcdir (conc types-file ".types")))) (dest (destination-repository mode)) (dfile (quotearg (slashify dest platform))) (ddir (shell-variable "DESTDIR" platform))) @@ -626,7 +649,7 @@ (let* ((cmd (install-file-command platform)) (mkdir (mkdir-command platform)) (sname (prefix srcdir name)) - (out (quotearg (conc inline-file ".inline"))) + (out (quotearg (prefix srcdir (conc inline-file ".inline")))) (dest (destination-repository mode)) (dfile (quotearg (slashify dest platform))) (ddir (shell-variable "DESTDIR" platform))) diff --git a/manual/Extensions b/manual/Extensions index 25bc75bb..9a397dee 100644 --- a/manual/Extensions +++ b/manual/Extensions @@ -290,19 +290,21 @@ property only makes sense for extension libraries. ====== types-file -[egg property] (types-file NAME) +[egg property] (types-file [NAME]) Specifies that a "type-database" file should be generated and installed for this component. This property is only used for -extension libraries. +extension libraries. The name is optional and defaults to the +name of the extensions (with the proper extension). ====== inline-file -[egg property] (inline-file NAME) +[egg property] (inline-file [NAME]) Specifies that an "inline" file should be generated and installed for this component. This property is only used for extension -libraries. +libraries. The name is optional and defaults to the +name of the extensions (with the proper extension). ====== custom-buildTrap