Open cfallin opened 6 years ago
Optima implements its failure handling (move to the next clause if it exists, or signal an error) with %fail
symbol macro and (symbol-macrolet (%fail ...)) ...)
which shadows the global %fail
.
The problem is that Iterate always expand all macro forms in its subforms in order to find its iterate special clauses. This is done directly by macroexpand
which does not consider the outer macrolet
s and symbol-macrolet
s. So this is a fundamental implementation conflict.
You can say this is a problem in Iterate. However I encourage you to move to trivia which does not use macrolet, is compatible to optima, is faster, is more extensible, and works perfectly with iterate. I designed it with this problem in mind.
OK, thanks very much -- I'll take a look!
With the following program (tested on SBCL), there seems to be a conflict of some sort between optima's
match
and rutils'iter
:This will raise a condition with error message "Not pattern matching."
From the
macroexpand
output, it appears that the redefinition of the%fail
macro inside each match code block is not working:(IF (EQL I 1) 'X (ERROR "Not pattern matching."))
. I'm not very well-versed in Lisp macros; could this have something to do with the use of the symbol macro infail.lisp
, combined with use inside the body of another macro?In any case, this was very surprising behavior and cost a bit of debugging time for me -- hopefully there's an easy fix! Thanks for the package in any case!