guile-user
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: expression and definition context in Scheme


From: Linus Björnstam
Subject: Re: expression and definition context in Scheme
Date: Tue, 30 Aug 2022 12:47:06 +0200
User-agent: Cyrus-JMAP/3.7.0-alpha0-841-g7899e99a45-fm-20220811.002-g7899e99a

I am working on a patch to guile to add definitions to just about every body 
except for (begin ...) outside definition context.

The patch is trivial, but I have to document it and a patch to r6rs that makes 
the r6rs cons work according to spec.

I had a kid recently so it might take some time before I have any computer 
time, so if anyone has some time this is a really simple thing. You can find 
the first patch somewhere in this mailing list, it only changes the (begin 
...)s in the derived forms in (ice-9 boot-9) to (let () ...). Then i was going 
to copy the cond and case from the r6rs appendix and add some error reporting.

The most difficult part is documenting it :)

Andy have the idea hos blessing, and will mean guile gets define in expression 
context in when, unless, cond, case, while, and do as well as in derived forms.

-- 
  Linus Björnstam

On Sat, 27 Aug 2022, at 18:48, Damien Mattei wrote:
> Hello,
>
> i'm facing sometimes recursively the problem to have definitions in 
> expression context, which i manage every time by adding an upper empty 
> (let () my definitions goes here )
> the last case i was facing this probleme is defining a 'for macro:
>
> ;; scheme@(guile-user)> (for ({i <+ 0} {i < 5} {i <- {i + 1}}) (display 
> i) (newline))
> ;; 0
> ;; 1
> ;; 2
> ;; 3
> ;; 4
>
>
> (define-syntax for
>  
>   (syntax-rules ()
>    
>     ((_ (init test incrmt) b1 ...)
>
>        (let ()
>            init
>            (let loop ()
>               (when test
>                     b1 ...
>                     incrmt
>                     (loop)))))))
>
> this one fails in my Scheme+ code below:
> (define (compute-carries n)
>
>   (for ( {k <+ 0}  {k <= n}  {k <- {k + 1}} )
>
>        { Ckp1 <+ (compute-Ck-plus1 k) }
>        (display-nl Ckp1)))
>
> because { Ckp1 <+ (compute-Ck-plus1 k) } expands in :
> (define Ckp1 (compute-Ck-plus1 k))
> and i get a compilation error:
> ;;; Syntax error:
> ;;; logic-syracuse+.scm:15:7: definition in expression context, where 
> definitions are not allowed, in form (define Ckp1 (compute-Ck-plus1 k))
>
> so i replace my 'for macro definition with:
>
> (define-syntax for
>  
>   (syntax-rules ()
>    
>     ((_ (init test incrmt) b1 ...)
>
>        (let ()
>            init
>            (let loop ()
>               (when test
>                 (let ()
>                     b1 ...
>                     incrmt
>                     (loop))))))))
>
> and it works, but you will notice an abusive use of empty (let () ...) 
> in the code to avoid the restrictions of definitions not allowed in 
> expression context. 
>
> My ideas is as it is so easy to cheat the compiler from seeing the 
> expressio context why does the compiler restrict this? expression and 
> defintion context, i'm not sure they are in scheme standarts, are they 
> really usefull?
> why not remove this from Scheme at all?
>
> Regards,
>
> Damien



reply via email to

[Prev in Thread] Current Thread [Next in Thread]