guile-user
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: custom module loading and compilation


From: Nala Ginrut
Subject: Re: custom module loading and compilation
Date: Mon, 13 May 2024 22:54:21 +0900

Hi Paul!
I don't know why you don't use the standard module definition and
import/export interface, but if you do want to play modules with
the introspection functions, here's a hint for you:

---------------------------------------------------------------------------
 (define (export-all-from-module! module-name)
   (let ((mod (resolve-module module-name)))
     (module-for-each (lambda (s m)
                        (module-add! (current-module) s m)) mod))))
---------------------------------------------------------------------------

This function can be used to export all symbols from a specified
module-name. You may modify it for your case.

Best regards.

On Sat, May 11, 2024 at 5:03 PM Paul Jarc <prj@case.edu> wrote:

> Hi.  I'm writing a custom module system that avoids the standard
> search path and list-of-symbols naming scheme.  Instead of using
> use-modules and define-module, I have a roughly similar procedure,
> let's call it my-load, that creates a module with make-module and
> loads a file into it with primitive-load.  I want to make my-load
> automatically available within the modules I load so that they can use
> it to load other modules too.  So my-load adds itself to each new
> module using module-define! before calling primitive-load.
>
> This works when I run Guile with --no-auto-compile, but with
> compilation enabled, I get:
> ;;; Unbound variable: my-load
> How can I make the binding visible to the compiler?
>
> ;;main.scm
> (define (my-load path-to-macros)
>   (let ((new-module (make-module 0 `(,(resolve-interface '(guile))))))
>     (module-define! new-module 'my-load my-load)
>     (save-module-excursion
>       (lambda ()
>         (set-current-module new-module)
>         (primitive-load path-to-macros)))
>     (let ((interface '(my-macro)))
>       (for-each (lambda (sym)
>                   (module-define! (current-module) sym
>                                   (module-ref new-module sym)))
>                 interface))))
> (eval-when (compile load eval)
>   (my-load "/path/to/macros1.scm"))
> (display (my-macro 5))
> (newline)
>
> ;;macros1.scm
> (eval-when (compile load eval)
>   (my-load "/path/to/macros2.scm"))
> (display (my-macro 3))
> (newline)
>
> ;;macros2.scm
> (define-syntax my-macro
>   (syntax-rules ()
>     ((_ x) (+ x x))))
>
>


reply via email to

[Prev in Thread] Current Thread [Next in Thread]