all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Oleh Krehel <ohwoeowho@gmail.com>
To: Marcin Borkowski <mbork@mbork.pl>
Cc: Christopher Allan Webber <cwebber@dustycloud.org>,
	Emacs developers <emacs-devel@gnu.org>
Subject: Re: parinfer-mode for Emacs might be neat for encouraging Lisp adoption
Date: Fri, 13 Nov 2015 12:32:17 +0100	[thread overview]
Message-ID: <874mgq879a.fsf@gmail.com> (raw)
In-Reply-To: <871tbv4c9a.fsf@mbork.pl> (Marcin Borkowski's message of "Thu, 12 Nov 2015 13:45:37 +0100")

Marcin Borkowski <mbork@mbork.pl> writes:

> On 2015-11-12, at 00:30, Christopher Allan Webber <cwebber@dustycloud.org> wrote:
>
>> Here's a project borrowing some neat ideas from Emacs and extensions
>> (especially paredit) on lisp editing and providing some of its own
>> ideas, too:
>>
>>   http://shaunlebron.github.io/parinfer/index.html
>>
>> I could imagine this could make GNU Emacs an even better lisp hacking
>> environment for some than it already is, or make jumping in easier, for
>> some people.  Maybe someone will be inspired and add a plugin for it?
>> There's a space listed for editor implementations here:
>>
>>   http://shaunlebron.github.io/parinfer/index.html#editor-plugins
>>
>> I don't have time to work on this, but I imagine someone on this list
>> might find it interesting enough to take for a spin, so I thought I'd
>> post it here.  At the very least, it's clearly critical for GNU Emacs to
>> be the most advanced lisp editing environment there is. ;)
>
> Oleh's lispy does a similar (though not identical) thing.

I've looked through the Parinfer web page and I don't think it's a great
idea (it's a neat trick though):

- It doesn't solve the problem of pasting unbalanced code.
- It relies on indentation to guess the thing to do.
- The thing to do might be surprising.
+ It balances parens for potentially generic commands that know nothing
  of Parinfer.

I think the first 3 negative points probably outweigh the single
positive point. Still, it would be cool to try it if anyone is up for
implementing it.

By the way, is anyone else on emacs-devel using lispy?  It's a really
cool way to quickly navigate, edit, examine, and debug Elisp.  It was
intended to be an easier Paredit, so picking it up shouldn't be too
hard, but it will probably take a long while to pick up everything and
reach top efficiency. See https://github.com/abo-abo/lispy if you're
interested.

It also has a bunch of integration tests (I saw this discussed in a
recent thread). The tests look like this:

    (should (string= (lispy-with "(|(a) (b) (c))" "j")
                     "((a) |(b) (c))"))

The parts are:

1. The buffer state before, including point and mark.
2. The user input.
3. The buffer state after, including point and mark.

There are around 700 of these tests and they run very fast, around 1.5s
to finish all of them. I think it would be cool for ERT to have this
kind of interface, and functions like `forward-list', `up-list',
`beginning-of-defun' etc could be tested this way.

These type of tests are also a good way to learn new bindings (since
they're built into the test), and what they should do in specific
situations (since it's not easy for the user to experience each
situation which results in a different branch taken by the command in
question).



  reply	other threads:[~2015-11-13 11:32 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-11-11 23:30 parinfer-mode for Emacs might be neat for encouraging Lisp adoption Christopher Allan Webber
2015-11-12 12:45 ` Marcin Borkowski
2015-11-13 11:32   ` Oleh Krehel [this message]
2015-11-13 14:49     ` Marcin Borkowski
2015-11-13 15:34     ` João Távora
2015-11-13 15:57       ` Marcin Borkowski
2015-11-13 15:58       ` Marcin Borkowski
2015-11-13 16:00         ` João Távora
2015-11-20  2:37           ` Stefan Monnier
     [not found]     ` <CALDnm53TD9N6ZYhALP4ynVANAUpKJTWATNmL_FA80JrOpdBErQ@mail.gmail.com>
     [not found]       ` <877fll7w18.fsf@gmail.com>
2015-11-13 15:55         ` João Távora
2015-11-13 16:15           ` Oleh Krehel
2016-02-15 20:05 ` Christopher Allan Webber

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=874mgq879a.fsf@gmail.com \
    --to=ohwoeowho@gmail.com \
    --cc=cwebber@dustycloud.org \
    --cc=emacs-devel@gnu.org \
    --cc=mbork@mbork.pl \
    /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.