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.
next prev parent 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).