all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: pjb@informatimago.com (Pascal J. Bourguignon)
To: help-gnu-emacs@gnu.org
Subject: Re: Element-Relative Sequence Insertion
Date: Thu, 11 Jun 2009 16:36:25 +0200	[thread overview]
Message-ID: <7chbym25xy.fsf@pbourguignon.anevia.com> (raw)
In-Reply-To: h0r3ng$n4q$1@news.onet.pl

Marc Tfardy <bum@cyk.cyk> writes:

> Pascal J. Bourguignon schrieb:
>> Nordlöw <per.nordlow@gmail.com> writes:
>>
>>> On 11 Juni, 14:38, p...@informatimago.com (Pascal J. Bourguignon)
>>> wrote:
>>>> Nordlöw <per.nord...@gmail.com> writes:
>>>>> How do I insert an element (object) relative to another in a sequence
>>>>> (or list in my case)? Example:
>>>>> (insert-after 'X '(a b c) 'b)  => '(a b X c)
>>>>> (insert-before 'X '(a b c) b)  => '(a X b c)
>>>> This is not what you want.  You don't what these function to return a
>>>> 2-element lists, the first of which is the symbol quote.  Unless
>>>> you're doing meta-programming you never want to have such a result.
>>>>
>>>> You wan this:
>>>>
>>>>    (insert-after 'X '(a b c)  'b)  -->  (a b X c)
>>>>    (insert-before 'X '(a b c) 'b)  -->  (a X b c)
>>>>
>>>> Also, you may want to mention whether your insert-after and
>>>> insert-before function are destructive or non-destructive.  Since you
>>>> show as only specification examples using literal data, we will assume
>>>> you want them to be non-destructive.
>>>>
>>>> So you do that, just by doing it.  There's nothing simplier.
>>>>
>>>> (defun insert-after (new list old)
>>>>    (cond ((null list) '())
>>>>          ((eql old (car list))  (cons (car list) (cons new (cdr list))))
>>>>          (t (cons (car list) (insert-after new (cdr list) old)))))
>>>>
>>>> (defun insert-before (new list old)
>>>>    (cond ((null list) '())
>>>>          ((eql old (car list))  (cons new list))
>>>>          (t (cons (car list) (insert-before new (cdr list) old)))))
>>>>
>>>> --
>>>> __Pascal Bourguignon__
>>> But how do I implement insert-after() and insert-before()? I guess the
>>> code in the end doesn't do anything meaningful :)
>>
>> It does, but you have to decrypt it first.
>
> (defun insert-after (elt lst new)
>   (cond ((null lst)
>          '())
>         ((eq new (car lst))
>          (cons (car lst) (cons elt (cdr lst))))
>         (t
>          (cons (car lst) (insert-after elt (cdr lst) new)))))
>
> (defun insert-before (elt lst new)
>   (cond ((null lst)
>          '())
>         ((eq new (car lst))
>          (cons elt lst))
>         (t
>          (cons (car lst) (insert-before elt (cdr lst) new)))))
>
> What is the price? ;-)

What's the point in renaming the parameters and introducing bugs?

Check again the order of the parameters!

Notice that (eq 3.141592 3.141592) --> nil ; which is the reason why
eql should be used by default.

And bad points for not being able to use rot13.

You lose.   :-)
-- 
__Pascal Bourguignon__


  reply	other threads:[~2009-06-11 14:36 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-06-11 12:11 Element-Relative Sequence Insertion Nordlöw
2009-06-11 12:38 ` Pascal J. Bourguignon
2009-06-11 12:51   ` Nordlöw
2009-06-11 13:01     ` Pascal J. Bourguignon
2009-06-11 14:18       ` Marc Tfardy
2009-06-11 14:36         ` Pascal J. Bourguignon [this message]
2009-06-11 15:01           ` Marc Tfardy
2009-06-13 16:47           ` Johan Bockgård

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

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

  git send-email \
    --in-reply-to=7chbym25xy.fsf@pbourguignon.anevia.com \
    --to=pjb@informatimago.com \
    --cc=help-gnu-emacs@gnu.org \
    /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.
Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/emacs.git
	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.