summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--elisp/geiser-plt.el2
-rw-r--r--scheme/plt/geiser/modules.ss18
2 files changed, 12 insertions, 8 deletions
diff --git a/elisp/geiser-plt.el b/elisp/geiser-plt.el
index 1db0ec9..16c0b96 100644
--- a/elisp/geiser-plt.el
+++ b/elisp/geiser-plt.el
@@ -86,7 +86,7 @@ This function uses `geiser-plt-init-file' if it exists."
`(dynamic-require ''geiser ',proc)))
(defconst geiser-plt--module-re
- "^(module +\\(([^)]+)\\)")
+ "^(module +\\([^ ]+\\)")
(defun geiser-plt--explicit-module ()
(save-excursion
diff --git a/scheme/plt/geiser/modules.ss b/scheme/plt/geiser/modules.ss
index a1094af..142cf1e 100644
--- a/scheme/plt/geiser/modules.ss
+++ b/scheme/plt/geiser/modules.ss
@@ -40,14 +40,18 @@
((absolute-path? spec) `(file ,spec))
(else spec)))
-(define (module-spec->namespace mod-spec)
- (letrec ((spec (ensure-module-spec mod-spec))
- (handler (lambda (e)
- (load-module spec)
- (enter! #f)
- (module->namespace spec))))
+(define (module-spec->namespace spec)
+ (let* ((spec (ensure-module-spec spec))
+ (contract-handler (lambda (e)
+ (load-module spec)
+ (enter! #f)
+ (module->namespace spec)))
+ (filesystem-handler (lambda (e)
+ (when (symbol? spec)
+ (module->namespace `',spec)))))
(if spec
- (with-handlers ((exn:fail:contract? handler))
+ (with-handlers ((exn:fail:contract? contract-handler)
+ (exn:fail:filesystem? filesystem-handler))
(module->namespace spec))
(current-namespace))))