From 010633b20de9643ac34409552bbbb4366038ecf7 Mon Sep 17 00:00:00 2001 From: dos-reis Date: Wed, 9 Mar 2011 06:58:27 +0000 Subject: * interp/g-opt.boot (semiSimpleRelativeTo?): Consider conditionals. --- src/ChangeLog | 4 ++++ src/interp/g-opt.boot | 7 +++++-- 2 files changed, 9 insertions(+), 2 deletions(-) (limited to 'src') diff --git a/src/ChangeLog b/src/ChangeLog index 9bd16a82..a4fd1290 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,7 @@ +2011-03-09 Gabriel Dos Reis + + * interp/g-opt.boot (semiSimpleRelativeTo?): Consider conditionals. + 2011-03-07 Gabriel Dos Reis * algebra/catdef.spad.pamphlet (SemiRing): New category. diff --git a/src/interp/g-opt.boot b/src/interp/g-opt.boot index ad5d7b84..b7a72aca 100644 --- a/src/interp/g-opt.boot +++ b/src/interp/g-opt.boot @@ -463,8 +463,11 @@ $simpleVMoperators == ++ to the list of operators `ops'. semiSimpleRelativeTo?(form,ops) == atomic? form => true - form isnt [op,:args] or not symbol? op or not MEMQ(op,ops) => false - and/[semiSimpleRelativeTo?(f,ops) for f in args] + not symbol?(form.op) or not MEMQ(form.op,ops) => false + form.op is '%when => + and/[sideEffectFree? p and semiSimpleRelativeTo?(c,ops) + for [p,c] in form.args] + and/[semiSimpleRelativeTo?(f,ops) for f in form.args] ++ Return true if `form' os a side-effect free form. sideEffectFree? form == -- cgit v1.2.3