unofficial mirror of guile-user@gnu.org 
 help / color / mirror / Atom feed
From: Hans Aberg <haberg-1@telia.com>
To: Neil Jerram <neil@ossau.uklinux.net>
Cc: guile-user@gnu.org
Subject: Re: Backquote simplification
Date: Sat, 11 Dec 2010 09:33:45 +0100	[thread overview]
Message-ID: <C0D29AA3-44D5-4B0B-B4C7-AE79BFD91021@telia.com> (raw)
In-Reply-To: <878vzxqhow.fsf@ossau.uklinux.net>

On 11 Dec 2010, at 01:25, Neil Jerram wrote:

>> The reply I got was helpful, but I decided to settle for a macro
>> implementation:
>>
>> (use-syntax (ice-9 syncase))
>>
>> (define-syntax tuple
>>  (syntax-rules ()
>>    ((tuple xs ...)
>>     `(tuple ,xs ...))
>>    ((tuple x1 x2 . y)
>>     (append `(tuple ,x1 ,x2) y))
>>    ((tuple x1 . y)
>>     (append `(tuple ,x1) y))
>> ))
>
> OK, I roughly see that this solves your problem of wanting to  
> unquote an
> arbitrary number of list elements.  (Although I don't understand why  
> you
> need to do that.)

One reason is that in the normal syntax f(x_1, ..., x_k) there are two  
separate parts f and (x_1, ..., x_k) that are combined, whereas in  
Scheme it is combined to one (f x_1 ... x_k) and does not have a  
concept for the (x_1, ..., x_k). Another is that it is needed in the  
translation of expressions like f(g(x)) --> (f (g x)), and (f g)x -->  
((f g) x).

>> It behaves as I want in my context, a functional language on top of
>> Guile.
>
> Scheme is already a functional language, isn't it?

I am using Bison/Flex parser/lexer to generate a different syntax. It  
turns out to be a good help not having to implement the back-end.

>> I decided to implement the construct (lambda (x_1 ... x_k . y)
>> f)
>
> What syntax is that expression in?  In Scheme syntax, it's a lambda  
> that
> returns a value that is apparently unrelated to any of the arguments,
> and so could equally well be written as (lambda ignored-args f).

I implement it using Guile C calls, and when constructing using
scm_list_3(scm_sym_lambda, x, f), it turns out that x = (x_1 ... x_k .  
y) is an improper list.

>> using an improper list (x_1 ... x_k . y); when it is a proper list,
>> one just gets the fixed number of arguments construct.
>>
>> Then the object (x_1 ... x_k . y) also become available, so it is
>> possible to form
>>  (define f (lambda (x_1 ... x_k . y) (x_1 ... x_k . y)))
>
> How is this different from
>
>  (define f (lambda args args))
>
> ?

The form (x_1 ... x_k . y) is an improper list that requires at least  
k arguments, and the rest given arguments are put into y as a list.

>> Then one would expect f(a_1, ..., a_n), for n >= k, to be (a_1, ...,
>> a_n) - this a form of the identity.
>>
>> So to get this effect, I need a function g that can call improper
>> lists (g x_1, ..., x_k . y), where y is a list.
>
> As Dan pointed out, that is not an improper list.  It's a proper list.

That would be true if the evaluator does not try to evaluate the  
expression before the substitution of y. That works in the case of a  
freestanding (g x_1 ... x_k . y), but for some reason not in the form
   (lambda (x_1 ... x_k . y) (g x_1 ... x_k . y))

I do not know why.

> In the hope that these questions might be useful to at least one of  
> us...

I do not know what that means.




  reply	other threads:[~2010-12-11  8:33 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-12-09 11:00 Backquote simplification Hans Aberg
     [not found] ` <CCCBC725-4AE9-4585-B18D-7DF6650D5880@mac.com>
2010-12-09 19:44   ` Hans Aberg
2010-12-10 23:12     ` Neil Jerram
2010-12-11  0:03       ` Hans Aberg
2010-12-11  0:25         ` Neil Jerram
2010-12-11  8:33           ` Hans Aberg [this message]
2010-12-11 10:01             ` Neil Jerram
2010-12-11 10:09               ` Hans Aberg

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/guile/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=C0D29AA3-44D5-4B0B-B4C7-AE79BFD91021@telia.com \
    --to=haberg-1@telia.com \
    --cc=guile-user@gnu.org \
    --cc=neil@ossau.uklinux.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).