[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Is this a bug?
From: |
rixed |
Subject: |
Is this a bug? |
Date: |
Tue, 16 Aug 2011 14:36:11 +0200 |
User-agent: |
Mutt/1.5.20 (2009-06-14) |
Here are two simple files :
---[ woe.scm ]---
(define-syntax without-exception
(syntax-rules ()
((without-exception key thunk ...)
(catch key (lambda () thunk
...)
(lambda (a .
r) #f)))))
---[ test.scm ]---
(load "woe.scm")
(without-exception #t (display "toto\n"))
---[ EOF ]---
Now let's run it. Notice I clean my guile cache.
% sudo rm -rf ~/.cache/guile
% guile --version
guile (GNU Guile) 2.0.2.39-335c8
(...)
% guile -l test.scm
;;; note: auto-compilation is enabled, set GUILE_AUTO_COMPILE=0
;;; or pass the --no-auto-compile argument to disable.
;;; compiling /home/rixed/src/sact.junkie/test.scm
;;; /home/rixed/src/sact.junkie/test.scm:2:0: warning: possibly unbound
variable `without-exception'
;;; compiled
/home/rixed/.cache/guile/ccache/2.0-LE-8-2.0/home/rixed/src/sact.junkie/test.scm.go
;;; compiling /home/rixed/src/sact.junkie/woe.scm
;;; compiled
/home/rixed/.cache/guile/ccache/2.0-LE-8-2.0/home/rixed/src/sact.junkie/woe.scm.go
toto
Backtrace:
In ice-9/boot-9.scm:
170: 7 [catch #t #<catch-closure 155bd60> ...]
In unknown file:
?: 6 [catch-closure]
In ice-9/boot-9.scm:
62: 5 [call-with-prompt prompt0 ...]
In ice-9/eval.scm:
389: 4 [eval # #]
In ice-9/boot-9.scm:
2103: 3 [save-module-excursion #<procedure 181b280 at ice-9/boot-9.scm:3547:3
()>]
3554: 2 [#<procedure 181b280 at ice-9/boot-9.scm:3547:3 ()>]
In unknown file:
?: 1 [load-compiled/vm
"/home/rixed/.cache/guile/ccache/2.0-LE-8-2.0/home/rixed/src/sact.junkie/test.scm.go"]
In /home/rixed/src/sact.junkie/test.scm:
2: 0 [#<procedure 19cc700 ()>]
/home/rixed/src/sact.junkie/test.scm:2:0: In procedure #<procedure 19cc700 ()>:
/home/rixed/src/sact.junkie/test.scm:2:0: Wrong type to apply:
#<syntax-transformer without-exception>
This code used to work on guile 1.8, so what's wrong with it?
Also, setting GUILE_AUTO_COMPILE to 0 don't change anything, but incidentaly I
discovered this:
Let's change the file permissions so that guile can no more write into it's
cache, and lets touch
test.scm so that he'd like to recompile it:
% sudo chown root: -R ~/.cache/guile
% touch test.scm
% guile -l test.scm
;;; note: source file /home/rixed/src/sact.junkie/test.scm
;;; newer than compiled
/home/rixed/.cache/guile/ccache/2.0-LE-8-2.0/home/rixed/src/sact.junkie/test.scm.go
;;; note: auto-compilation is enabled, set GUILE_AUTO_COMPILE=0
;;; or pass the --no-auto-compile argument to disable.
;;; compiling /home/rixed/src/sact.junkie/test.scm
;;; WARNING: compilation of /home/rixed/src/sact.junkie/test.scm failed:
;;; ERROR: failed to create path for auto-compiled file
"/home/rixed/src/sact.junkie/test.scm"
toto
GNU Guile 2.0.2.39-335c8
Copyright (C) 1995-2011 Free Software Foundation, Inc.
Guile comes with ABSOLUTELY NO WARRANTY; for details type `,show w'.
This program is free software, and you are welcome to redistribute it
under certain conditions; type `,show c' for details.
Enter `,help' for help.
scheme@(guile-user)>
No more backtrace!
What's taking place?
Any idea of a workaround (apart from playing with file permissions in my cache)
?