Merge pull request #74 from koba-e964/master

[bugfix] macroexpand (Issue #68)
This commit is contained in:
Yuichi Nishiwaki 2014-03-24 10:38:29 +09:00
commit 48e58293dc
1 changed files with 37 additions and 22 deletions

View File

@ -213,7 +213,12 @@ macroexpand(pic_state *pic, pic_value expr, struct pic_senv *senv)
if (tag == pic->sDEFINE_LIBRARY) { if (tag == pic->sDEFINE_LIBRARY) {
struct pic_lib *prev = pic->lib; struct pic_lib *prev = pic->lib;
jmp_buf jmp, *prevjmp = pic->jmp;
bool name_restored = false;
/* restores pic->lib even if an error occurs */
if (setjmp(jmp) == 0) {
pic->jmp = &jmp;
if (pic_length(pic, expr) < 2) { if (pic_length(pic, expr) < 2) {
pic_error(pic, "syntax error"); pic_error(pic, "syntax error");
} }
@ -238,7 +243,17 @@ macroexpand(pic_state *pic, pic_value expr, struct pic_senv *senv)
} }
} }
pic_in_library(pic, prev->name); pic_in_library(pic, prev->name);
name_restored = true;
}
else {
if (! name_restored) {
pic_in_library(pic, prev->name);
}
}
pic->jmp = prevjmp;
if (pic->err) {
longjmp(*pic->jmp, 1);
}
return pic_none_value(); return pic_none_value();
} }