unofficial mirror of help-gnu-emacs@gnu.org
 help / color / mirror / Atom feed
* non word abbrevs
@ 2021-10-31  5:45 Jean-Christophe Helary
  2021-10-31 19:04 ` Stefan Monnier via Users list for the GNU Emacs text editor
  0 siblings, 1 reply; 21+ messages in thread
From: Jean-Christophe Helary @ 2021-10-31  5:45 UTC (permalink / raw)
  To: help-gnu-emacs

I'm trying to create abbrevs that do this

-> →
<- ← 

etc.

but Emacs won't allow that because the abbrevs are not "word constituents".

-- 
Jean-Christophe Helary @brandelune
https://mac4translators.blogspot.com
https://sr.ht/~brandelune/omegat-as-a-book/




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-10-31  5:45 non word abbrevs Jean-Christophe Helary
@ 2021-10-31 19:04 ` Stefan Monnier via Users list for the GNU Emacs text editor
  2021-11-01  7:57   ` Jean-Christophe Helary
  0 siblings, 1 reply; 21+ messages in thread
From: Stefan Monnier via Users list for the GNU Emacs text editor @ 2021-10-31 19:04 UTC (permalink / raw)
  To: help-gnu-emacs

Jean-Christophe Helary [2021-10-31 14:45:04] wrote:
> I'm trying to create abbrevs that do this
>
> -> →
> <- ← 
>
> etc.
>
> but Emacs won't allow that because the abbrevs are not "word constituents".

You need to change the `:regexp` on your abbrev table.
See `define-abbrev-table`.


        Stefan




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-10-31 19:04 ` Stefan Monnier via Users list for the GNU Emacs text editor
@ 2021-11-01  7:57   ` Jean-Christophe Helary
  2021-11-01 10:54     ` Emanuel Berg via Users list for the GNU Emacs text editor
  2021-11-01 12:03     ` Stefan Monnier
  0 siblings, 2 replies; 21+ messages in thread
From: Jean-Christophe Helary @ 2021-11-01  7:57 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: help-gnu-emacs



> On Nov 1, 2021, at 4:04, Stefan Monnier via Users list for the GNU Emacs text editor <help-gnu-emacs@gnu.org> wrote:
> 
> Jean-Christophe Helary [2021-10-31 14:45:04] wrote:
>> I'm trying to create abbrevs that do this
>> 
>> -> →
>> <- ← 
>> 
>> etc.
>> 
>> but Emacs won't allow that because the abbrevs are not "word constituents".
> 
> You need to change the `:regexp` on your abbrev table.
> See `define-abbrev-table`.

(define-abbrev-table 'arrows-abbrev-table
  '(("->" "→")
    ("<-"  "←")
    ("<->" "⇆")
    ("==>" "⇒")
    ("<==" "⇐")
    ("<=>" "⇔")
    )
    "Arrows as defined on my macOS side."
    :regexp "\(<?[-=]>?\)")

I must be missing something. I evaluate the expression but the abbrevs do not work.

Jean-Christophe 


^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-01  7:57   ` Jean-Christophe Helary
@ 2021-11-01 10:54     ` Emanuel Berg via Users list for the GNU Emacs text editor
  2021-11-01 12:03     ` Stefan Monnier
  1 sibling, 0 replies; 21+ messages in thread
From: Emanuel Berg via Users list for the GNU Emacs text editor @ 2021-11-01 10:54 UTC (permalink / raw)
  To: help-gnu-emacs

Jean-Christophe Helary wrote:

> (define-abbrev-table 'arrows-abbrev-table
>   '(("->" "→")
>     ("<-"  "←")
>     ("<->" "⇆")
>     ("==>" "⇒")
>     ("<==" "⇐")
>     ("<=>" "⇔")
>     )
>     "Arrows as defined on my macOS side."
>     :regexp "\(<?[-=]>?\)")
>
> I must be missing something. I evaluate the expression but
> the abbrevs do not work.

Try with just one arrow - the simplest - and see if you can
find the regexp that works for that ...

-- 
underground experts united
https://dataswamp.org/~incal




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-01  7:57   ` Jean-Christophe Helary
  2021-11-01 10:54     ` Emanuel Berg via Users list for the GNU Emacs text editor
@ 2021-11-01 12:03     ` Stefan Monnier
  2021-11-01 12:13       ` Jean-Christophe Helary
  1 sibling, 1 reply; 21+ messages in thread
From: Stefan Monnier @ 2021-11-01 12:03 UTC (permalink / raw)
  To: Jean-Christophe Helary; +Cc: help-gnu-emacs

>     :regexp "\(<?[-=]>?\)")
> I must be missing something.

Hmmm... backslashes?  ;-)
The above string is the same as "(<?[-=]>?)" (in recentish Emacsen the
above backslashes should presumably be highlighted in
a font-lock-warning color for that reason).

Beware also that this regexp is matched backwards and stops as soon as
it finds a match, so it finds the *shortest* match rather than the
longest match.  IOW the <? part will always match the empty string.


        Stefan




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-01 12:03     ` Stefan Monnier
@ 2021-11-01 12:13       ` Jean-Christophe Helary
  2021-11-01 12:43         ` Stefan Monnier via Users list for the GNU Emacs text editor
  2021-11-06  8:20         ` Jean-Christophe Helary
  0 siblings, 2 replies; 21+ messages in thread
From: Jean-Christophe Helary @ 2021-11-01 12:13 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: help-gnu-emacs



> On Nov 1, 2021, at 21:03, Stefan Monnier <monnier@iro.umontreal.ca> wrote:
> 
>>    :regexp "\(<?[-=]>?\)")
>> I must be missing something.
> 
> Hmmm... backslashes?  ;-)
> The above string is the same as "(<?[-=]>?)" (in recentish Emacsen the
> above backslashes should presumably be highlighted in
> a font-lock-warning color for that reason).

I'm trying in *scratch* with lisp-mode on a recent "master" and I don't get that...

> Beware also that this regexp is matched backwards and stops as soon as
> it finds a match, so it finds the *shortest* match rather than the
> longest match.  IOW the <? part will always match the empty string.

I've changed it to:

:regexp "\\([<>=-]+\\)"

this time using: 

(setq local-abbrev-table arrows-abbrev-table)

And I get a nice message that reads like this:

[## 0 0 0 0 0 0 0 0 0 0 <== <=> 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ==> 0 0 0 0 0 0 0 0 0 <- 0 0 0 0 0 0 0 0 <-> 0 0 0 -> 0 0 0]

And I guess that's a list that includes possible matches but I'm not seeing => / <= so I wonder.

Then, I enable abbrev-mode but nothing gets transformed...

:-( Jean-Christophe 


^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-01 12:13       ` Jean-Christophe Helary
@ 2021-11-01 12:43         ` Stefan Monnier via Users list for the GNU Emacs text editor
  2021-11-01 13:17           ` Jean-Christophe Helary
  2021-11-06  8:20         ` Jean-Christophe Helary
  1 sibling, 1 reply; 21+ messages in thread
From: Stefan Monnier via Users list for the GNU Emacs text editor @ 2021-11-01 12:43 UTC (permalink / raw)
  To: help-gnu-emacs

>>>    :regexp "\(<?[-=]>?\)")
>>> I must be missing something.
>> Hmmm... backslashes?  ;-)
>> The above string is the same as "(<?[-=]>?)" (in recentish Emacsen the
>> above backslashes should presumably be highlighted in
>> a font-lock-warning color for that reason).
>
> I'm trying in *scratch* with lisp-mode on a recent "master" and I don't get that...

I just tried it on my end with both `master` and Emacs-27.1

    emacs -Q
    :regexp "\(<?[-=]>?\)")

and the two backslashes got the `font-lock-warning-face` (the strings
are colored a kind of brick red and the warning is in red so it doesn't
stand out as much as I'd like but it's visible).

I wonder why you don't see that on your end.

> :regexp "\\([<>=-]+\\)"

And since Emacs will only use the shortest match, it will only use
one-char-long matches :-(

Try something like: "[^<>=-]\\([<>=-]+\\)"
[ Yes, this shortest match business is a PITA.  ]

> (setq local-abbrev-table arrows-abbrev-table)
>
> And I get a nice message that reads like this:
>
> [## 0 0 0 0 0 0 0 0 0 0 <== <=> 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ==>
> 0 0 0 0 0 0 0 0 0 <- 0 0 0 0 0 0 0 0 <-> 0 0 0 -> 0 0 0]

That's just the printed version of the vector that's used as an
"obarray".  It's mostly meaningless.

> And I guess that's a list that includes possible matches but I'm not seeing => / <= so I wonder.

As I said it's mostly meaningless: it includes *some* of the symbols but
not all.  I had a patch which introduced a real obarray type (instead
of abusing vectors), which could then be printed "properly", a bit like
hash tables, but it had its share of problems.

> Then, I enable abbrev-mode but nothing gets transformed...

That's because it only single-char matches occurred and you had no
single-char abbrev defined?


        Stefan




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-01 12:43         ` Stefan Monnier via Users list for the GNU Emacs text editor
@ 2021-11-01 13:17           ` Jean-Christophe Helary
  2021-11-01 13:49             ` Leo Butler
                               ` (2 more replies)
  0 siblings, 3 replies; 21+ messages in thread
From: Jean-Christophe Helary @ 2021-11-01 13:17 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: help-gnu-emacs



> On Nov 1, 2021, at 21:43, Stefan Monnier via Users list for the GNU Emacs text editor <help-gnu-emacs@gnu.org> wrote:
> 
>>>>   :regexp "\(<?[-=]>?\)")
>>>> I must be missing something.
>>> Hmmm... backslashes?  ;-)
>>> The above string is the same as "(<?[-=]>?)" (in recentish Emacsen the
>>> above backslashes should presumably be highlighted in
>>> a font-lock-warning color for that reason).
>> 
>> I'm trying in *scratch* with lisp-mode on a recent "master" and I don't get that...
> 
> I just tried it on my end with both `master` and Emacs-27.1
> 
>    emacs -Q
>    :regexp "\(<?[-=]>?\)")
> 
> and the two backslashes got the `font-lock-warning-face` (the strings
> are colored a kind of brick red and the warning is in red so it doesn't
> stand out as much as I'd like but it's visible).

Ok, I just rebuilt the latest master and emacs -Q shows them... And I am *not* going to dive into my init.el at this time of the day...

>> :regexp "\\([<>=-]+\\)"
> 
> And since Emacs will only use the shortest match, it will only use
> one-char-long matches :-(
> 
> Try something like: "[^<>=-]\\([<>=-]+\\)"
> [ Yes, this shortest match business is a PITA.  ]

My abbrevs are arrows composed of < or > at the tips and - or = with a minimum of 2 characters and a max of 3:

→ ⇒
← ⇐
↔ ⇔

In a different world, I'd try [<>=-]{2,3}

Is that what you mean ?

JC


^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-01 13:17           ` Jean-Christophe Helary
@ 2021-11-01 13:49             ` Leo Butler
  2021-11-01 14:03             ` tomas
  2021-11-01 17:58             ` Stefan Monnier
  2 siblings, 0 replies; 21+ messages in thread
From: Leo Butler @ 2021-11-01 13:49 UTC (permalink / raw)
  To: Jean-Christophe Helary; +Cc: help-gnu-emacs, Stefan Monnier

Jean-Christophe Helary <lists@traduction-libre.org> writes:

>> On Nov 1, 2021, at 21:43, Stefan Monnier via Users list for the GNU Emacs text editor <help-gnu-emacs@gnu.org> wrote:
>> 
>>>>>   :regexp "\(<?[-=]>?\)")
>>>>> I must be missing something.
>>>> Hmmm... backslashes?  ;-)
>>>> The above string is the same as "(<?[-=]>?)" (in recentish Emacsen the
>>>> above backslashes should presumably be highlighted in
>>>> a font-lock-warning color for that reason).
>>> 
>>> I'm trying in *scratch* with lisp-mode on a recent "master" and I don't get that...
>> 
>> I just tried it on my end with both `master` and Emacs-27.1
>> 
>>    emacs -Q
>>    :regexp "\(<?[-=]>?\)")
>> 
>> and the two backslashes got the `font-lock-warning-face` (the strings
>> are colored a kind of brick red and the warning is in red so it doesn't
>> stand out as much as I'd like but it's visible).
>
> Ok, I just rebuilt the latest master and emacs -Q shows them... And I am *not* going to dive into my init.el at this time of the day...
>
>>> :regexp "\\([<>=-]+\\)"
>> 
>> And since Emacs will only use the shortest match, it will only use
>> one-char-long matches :-(
>> 
>> Try something like: "[^<>=-]\\([<>=-]+\\)"
>> [ Yes, this shortest match business is a PITA.  ]
>
> My abbrevs are arrows composed of < or > at the tips and - or = with a minimum of 2 characters and a max of 3:
>
> → ⇒
> ← ⇐
> ↔ ⇔
>
> In a different world, I'd try [<>=-]{2,3}
>
> Is that what you mean ?

Try M-x regexp-builder RET

This is a fast way to check your regexps are matching the way you
intend.

Btw, it might be easier to do something like

(regexp-opt '("=>" "==>") "[^>=<]\\(?:")
===> "[^>=<]\\(?:=\\(?:=?>\\)\\)"

Btw, I just checked that regexp with regexp-builder and it matched only
2 strings in this buffer.

FWIW,
Leo



^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-01 13:17           ` Jean-Christophe Helary
  2021-11-01 13:49             ` Leo Butler
@ 2021-11-01 14:03             ` tomas
  2021-11-01 17:58             ` Stefan Monnier
  2 siblings, 0 replies; 21+ messages in thread
From: tomas @ 2021-11-01 14:03 UTC (permalink / raw)
  To: help-gnu-emacs

[-- Attachment #1: Type: text/plain, Size: 862 bytes --]

On Mon, Nov 01, 2021 at 10:17:28PM +0900, Jean-Christophe Helary wrote:
> 
> 
> > On Nov 1, 2021, at 21:43, Stefan Monnier via Users list for the GNU Emacs text editor <help-gnu-emacs@gnu.org> wrote:

[...]

> >> :regexp "\\([<>=-]+\\)"

Oh, yes: always double your backslashes (well /nearly/ [1] always).
The first ones are for Lisp's string syntax.

[...]

> In a different world, I'd try [<>=-]{2,3}

Emacs is your world, then. Well, nearly :) It groks {} repetitions
(cf. the docs). Note that they are spelt with a backslash (don't
forget to double it in string context). This would give:

      "...[<>=-]\\{2,3\\}..."

in your case (the dots are ellipses, for the rest of your regexp).

Cheers

[1] When you are writing the regexp in a Lisp string. Not when
   you are entering it interactively, e.g. in the minibuffer.

 - t

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 198 bytes --]

^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-01 13:17           ` Jean-Christophe Helary
  2021-11-01 13:49             ` Leo Butler
  2021-11-01 14:03             ` tomas
@ 2021-11-01 17:58             ` Stefan Monnier
  2 siblings, 0 replies; 21+ messages in thread
From: Stefan Monnier @ 2021-11-01 17:58 UTC (permalink / raw)
  To: Jean-Christophe Helary; +Cc: help-gnu-emacs

>> Try something like: "[^<>=-]\\([<>=-]+\\)"
>> [ Yes, this shortest match business is a PITA.  ]
>
> My abbrevs are arrows composed of < or > at the tips and - or = with
> a minimum of 2 characters and a max of 3:
>
> → ⇒
> ← ⇐
> ↔ ⇔
>
> In a different world, I'd try [<>=-]{2,3}
>
> Is that what you mean ?

No, the [^<>=-] is the important part: it tells Emacs to keep looking
(going backward) for a longer match.

If you use "[<>=-]\\{2,3\\}" (which does exist in our beloved ELisp
world), then Emacs's regexp matcher will go as follows:

- Let's say we're in a line with "<=> hello", with point just after the ">".
- The regexp search will first try to match (backward) ">" against the
  regexp, which will fail.
- It will then try to match "=>" against the regexp, which will succeed.
- At this point it stops and fails to notice that the regexp would also
  have matched "<=>", so you won't get the abbrev expansion you wanted.


-- Stefan




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-01 12:13       ` Jean-Christophe Helary
  2021-11-01 12:43         ` Stefan Monnier via Users list for the GNU Emacs text editor
@ 2021-11-06  8:20         ` Jean-Christophe Helary
  2021-11-06 22:32           ` Stefan Monnier
  1 sibling, 1 reply; 21+ messages in thread
From: Jean-Christophe Helary @ 2021-11-06  8:20 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: help-gnu-emacs

Ok, so this time I try your regexp (thank you by the way):

> On Nov 1, 2021, at 21:13, Jean-Christophe Helary <lists@traduction-libre.org> wrote:


(define-abbrev-table 'arrows-abbrev-table
 '(("->" "→")
   ("<-"  "←")
   ("<->" "⇆")
   ("==>" "⇒")
   ("<==" "⇐")
   ("<=>" "⇔")
   )
   "Arrows as defined on my macOS side."
   :regexp "[^<>=-]\\([<>=-]+\\)")

(setq local-abbrev-table arrows-abbrev-table)

and I have the abbrev-mode enabled in the *scratch* buffer where I run that, and nothing happens when I type -> for ex... 😢

-- 
Jean-Christophe Helary @brandelune
https://mac4translators.blogspot.com
https://sr.ht/~brandelune/omegat-as-a-book/




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-06  8:20         ` Jean-Christophe Helary
@ 2021-11-06 22:32           ` Stefan Monnier
  2021-11-07  0:01             ` Jean-Christophe Helary
  0 siblings, 1 reply; 21+ messages in thread
From: Stefan Monnier @ 2021-11-06 22:32 UTC (permalink / raw)
  To: Jean-Christophe Helary; +Cc: help-gnu-emacs

Jean-Christophe Helary [2021-11-06 17:20:58] wrote:
> Ok, so this time I try your regexp (thank you by the way):
>> On Nov 1, 2021, at 21:13, Jean-Christophe Helary <lists@traduction-libre.org> wrote:
> (define-abbrev-table 'arrows-abbrev-table
>  '(("->" "→")
>    ("<-"  "←")
>    ("<->" "⇆")
>    ("==>" "⇒")
>    ("<==" "⇐")
>    ("<=>" "⇔")
>    )
>    "Arrows as defined on my macOS side."
>    :regexp "[^<>=-]\\([<>=-]+\\)")
>
> (setq local-abbrev-table arrows-abbrev-table)
>
> and I have the abbrev-mode enabled in the *scratch* buffer where I run
>  that, and nothing happens when I type -> for ex... 😢

I tried the above and then `M-x expand-abbrev` and it worked for my test
case, so I guess the problem is in the auto-triggering of abbrevs down
in `self-insert-command`.

And indeed I see:

    if (!NILP (BVAR (current_buffer, abbrev_mode))
        && synt != Sword
        && NILP (BVAR (current_buffer, read_only))
        && PT > BEGV
        && (SYNTAX (!NILP (BVAR (current_buffer, enable_multibyte_characters))
                    ? XFIXNAT (Fprevious_char ())
                    : UNIBYTE_TO_CHAR (XFIXNAT (Fprevious_char ())))
            == Sword))

so it looks like the "auto expand abbrev" feature only works right after
a word char, so basically only works for abbrevs whose last char has
word syntax.

You might want to `M-x report-emacs-bug` and request that this
constraint be made more flexible.


        Stefan




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-06 22:32           ` Stefan Monnier
@ 2021-11-07  0:01             ` Jean-Christophe Helary
  2021-11-07  3:15               ` Stefan Monnier via Users list for the GNU Emacs text editor
  0 siblings, 1 reply; 21+ messages in thread
From: Jean-Christophe Helary @ 2021-11-07  0:01 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: help-gnu-emacs

Thank you Stephan for checking all that.

> On Nov 7, 2021, at 7:32, Stefan Monnier <monnier@iro.umontreal.ca> wrote:
> 
> I tried the above and then `M-x expand-abbrev` and it worked for my test
> case, so I guess the problem is in the auto-triggering of abbrevs down
> in `self-insert-command`.
> 
> And indeed I see:
> 
>    if (!NILP (BVAR (current_buffer, abbrev_mode))
>        && synt != Sword
>        && NILP (BVAR (current_buffer, read_only))
>        && PT > BEGV
>        && (SYNTAX (!NILP (BVAR (current_buffer, enable_multibyte_characters))
>                    ? XFIXNAT (Fprevious_char ())
>                    : UNIBYTE_TO_CHAR (XFIXNAT (Fprevious_char ())))
>            == Sword))
> 
> so it looks like the "auto expand abbrev" feature only works right after
> a word char, so basically only works for abbrevs whose last char has
> word syntax.

Which kind of defeats the idea of being able to define a regex in the first place...

> You might want to `M-x report-emacs-bug` and request that this
> constraint be made more flexible.

I will. Thank you again.

-- 
Jean-Christophe Helary @brandelune
https://mac4translators.blogspot.com
https://sr.ht/~brandelune/omegat-as-a-book/




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-07  0:01             ` Jean-Christophe Helary
@ 2021-11-07  3:15               ` Stefan Monnier via Users list for the GNU Emacs text editor
  2021-11-07  3:24                 ` Jean-Christophe Helary
  2021-11-07  4:06                 ` Emanuel Berg via Users list for the GNU Emacs text editor
  0 siblings, 2 replies; 21+ messages in thread
From: Stefan Monnier via Users list for the GNU Emacs text editor @ 2021-11-07  3:15 UTC (permalink / raw)
  To: help-gnu-emacs

>> so it looks like the "auto expand abbrev" feature only works right after
>> a word char, so basically only works for abbrevs whose last char has
>> word syntax.
> Which kind of defeats the idea of being able to define a regex in the first place...

Not completely: the original motivation for adding that `:regexp`
keyword was to handle abbrevs of the form "`foo" as well as others of
the form "foo/bar" ;-)

>> You might want to `M-x report-emacs-bug` and request that this
>> constraint be made more flexible.
> I will. Thank you again.

In the mean time, you might be able to implement
a `post-self-insert-hook` which runs expands your abbrevs.
You could start with something like:

    (add-hook 'post-self-insert-hook #'my-expand-arrow-abbrevs)
    (defun my-expand-arrow-abbrevs ()
      (if (memq (char-before) '(?= ?< ?-))
          (expand-abbrev)))


-- Stefan




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-07  3:15               ` Stefan Monnier via Users list for the GNU Emacs text editor
@ 2021-11-07  3:24                 ` Jean-Christophe Helary
  2021-11-07  4:11                   ` Emanuel Berg via Users list for the GNU Emacs text editor
  2021-11-08  5:36                   ` Kevin Vigouroux via Users list for the GNU Emacs text editor
  2021-11-07  4:06                 ` Emanuel Berg via Users list for the GNU Emacs text editor
  1 sibling, 2 replies; 21+ messages in thread
From: Jean-Christophe Helary @ 2021-11-07  3:24 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: help-gnu-emacs



> On Nov 7, 2021, at 12:15, Stefan Monnier via Users list for the GNU Emacs text editor <help-gnu-emacs@gnu.org> wrote:

> Not completely: the original motivation for adding that `:regexp`
> keyword was to handle abbrevs of the form "`foo" as well as others of
> the form "foo/bar" ;-)

And the overall feature seems severely under-documented... Honestly, I barely understood your explanations...

Maybe expecting to have abbrevs work way was a mistake, but it does not seem possible to have (easy...) arbitrary string expansion in out-of-the-box-emacs without abbrevs.

Would there be another more idiomatic way ?
I know about assigning key shortcuts to arbitrary string insertion, but that needlessly fills the keymaps with shortcuts that could be put to better use *and* the combination would be longer to enter than a normal abbrev...

> 
>>> You might want to `M-x report-emacs-bug` and request that this
>>> constraint be made more flexible.
>> I will. Thank you again.
> 
> In the mean time, you might be able to implement
> a `post-self-insert-hook` which runs expands your abbrevs.

Christmas in November ? :-)

> You could start with something like:
> 
>    (add-hook 'post-self-insert-hook #'my-expand-arrow-abbrevs)
>    (defun my-expand-arrow-abbrevs ()
>      (if (memq (char-before) '(?= ?< ?-))
>          (expand-abbrev)))

I'll try that and will report. Thank you !


-- 
Jean-Christophe Helary @brandelune
https://mac4translators.blogspot.com
https://sr.ht/~brandelune/omegat-as-a-book/




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-07  3:15               ` Stefan Monnier via Users list for the GNU Emacs text editor
  2021-11-07  3:24                 ` Jean-Christophe Helary
@ 2021-11-07  4:06                 ` Emanuel Berg via Users list for the GNU Emacs text editor
  1 sibling, 0 replies; 21+ messages in thread
From: Emanuel Berg via Users list for the GNU Emacs text editor @ 2021-11-07  4:06 UTC (permalink / raw)
  To: help-gnu-emacs

Stefan Monnier via Users list for the GNU Emacs text editor wrote:

> In the mean time, you might be able to implement
> a `post-self-insert-hook` which runs expands your abbrevs.
> You could start with something like:
>
>     (add-hook 'post-self-insert-hook #'my-expand-arrow-abbrevs)
>     (defun my-expand-arrow-abbrevs ()
>       (if (memq (char-before) '(?= ?< ?-))
>           (expand-abbrev)))

Isn't it faster to type something, e.g. "leftarr" or
something, anyway? I mean, compared with typing "<-" ...

But I get it one would like it configurable anyway, and not
a bug.

-- 
underground experts united
https://dataswamp.org/~incal




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-07  3:24                 ` Jean-Christophe Helary
@ 2021-11-07  4:11                   ` Emanuel Berg via Users list for the GNU Emacs text editor
  2021-11-08  5:36                   ` Kevin Vigouroux via Users list for the GNU Emacs text editor
  1 sibling, 0 replies; 21+ messages in thread
From: Emanuel Berg via Users list for the GNU Emacs text editor @ 2021-11-07  4:11 UTC (permalink / raw)
  To: help-gnu-emacs

Jean-Christophe Helary wrote:

>> On Nov 7, 2021, at 12:15, Stefan Monnier via Users list for
>> the GNU Emacs text editor <help-gnu-emacs@gnu.org> wrote:
>
>> Not completely: the original motivation for adding that `:regexp`
>> keyword was to handle abbrevs of the form "`foo" as well as others of
>> the form "foo/bar" ;-)
>
> And the overall feature seems severely under-documented...
> Honestly, I barely understood your explanations...

It doesn't execute if the last char is for example a dash ...

Try an abbrev that is "a-b" (not "a to b", the chars a, dash,
and b), the "a-b" abbrev will work as b is the last char, not
the dash this time.

(dash is "HYPHEN-MINUS" officially :))

> Maybe expecting to have abbrevs work way was a mistake, but
> it does not seem possible to have (easy...) arbitrary string
> expansion in out-of-the-box-emacs without abbrevs.

It is easy! Try setup an abbrev that is "aaaz" to "bbbz", with
the punctuation chars it doesn't work since it doesn't
trigger, that's a bug, good work YOU for finding it! Your code
works fine with "aaaz" to "bbbz", well, details aside since
you tried to do something else.

> Would there be another more idiomatic way ?

No, you did it the right way, Emacs did it the wrong way, but
as long as we have our captain going at - I don't know how
many percent? - but surely plenty enough to fix these kind of
bugs :)

-- 
underground experts united
https://dataswamp.org/~incal




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-07  3:24                 ` Jean-Christophe Helary
  2021-11-07  4:11                   ` Emanuel Berg via Users list for the GNU Emacs text editor
@ 2021-11-08  5:36                   ` Kevin Vigouroux via Users list for the GNU Emacs text editor
  2021-11-08  7:18                     ` Jean-Christophe Helary
  1 sibling, 1 reply; 21+ messages in thread
From: Kevin Vigouroux via Users list for the GNU Emacs text editor @ 2021-11-08  5:36 UTC (permalink / raw)
  To: help-gnu-emacs

Jean-Christophe Helary <lists@traduction-libre.org> writes:

>> On Nov 7, 2021, at 12:15, Stefan Monnier via Users list for the GNU Emacs text editor <help-gnu-emacs@gnu.org> wrote:
>
>> Not completely: the original motivation for adding that `:regexp`
>> keyword was to handle abbrevs of the form "`foo" as well as others of
>> the form "foo/bar" ;-)
>
> And the overall feature seems severely under-documented... Honestly, I barely understood your explanations...
>
> Maybe expecting to have abbrevs work way was a mistake, but it does not seem possible to have (easy...) arbitrary string expansion in out-of-the-box-emacs without abbrevs.
>
> Would there be another more idiomatic way ?
> I know about assigning key shortcuts to arbitrary string insertion,
> but that needlessly fills the keymaps with shortcuts that could be put
> to better use *and* the combination would be longer to enter than a
> normal abbrev...
>

You can insert a Unicode character with `insert-char'. This does not
shorten the typing but at least you can insert any character easily.

In word processors, you can insert these characters if they are
available in the dialog box called “Special Characters”.

>> 
>>>> You might want to `M-x report-emacs-bug` and request that this
>>>> constraint be made more flexible.
>>> I will. Thank you again.
>> 
>> In the mean time, you might be able to implement
>> a `post-self-insert-hook` which runs expands your abbrevs.
>
> Christmas in November ? :-)
>
>> You could start with something like:
>> 
>>    (add-hook 'post-self-insert-hook #'my-expand-arrow-abbrevs)
>>    (defun my-expand-arrow-abbrevs ()
>>      (if (memq (char-before) '(?= ?< ?-))
>>          (expand-abbrev)))
>
> I'll try that and will report. Thank you !

-- 
Best regards,
Kevin Vigouroux



^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-08  5:36                   ` Kevin Vigouroux via Users list for the GNU Emacs text editor
@ 2021-11-08  7:18                     ` Jean-Christophe Helary
  2021-11-08 23:29                       ` Stefan Monnier via Users list for the GNU Emacs text editor
  0 siblings, 1 reply; 21+ messages in thread
From: Jean-Christophe Helary @ 2021-11-08  7:18 UTC (permalink / raw)
  To: Kevin Vigouroux; +Cc: help-gnu-emacs

>> Maybe expecting to have abbrevs work way was a mistake, but it does not seem possible to have (easy...) arbitrary string expansion in out-of-the-box-emacs without abbrevs.
>> 
>> Would there be another more idiomatic way ?
>> I know about assigning key shortcuts to arbitrary string insertion,
>> but that needlessly fills the keymaps with shortcuts that could be put
>> to better use *and* the combination would be longer to enter than a
>> normal abbrev...
>> 
> 
> You can insert a Unicode character with `insert-char'. This does not
> shorten the typing but at least you can insert any character easily.

Thank you. I am really just interested in having "proper" text expansions like what I have on the OS side. I fail to see the logic of limiting abbrevs to "word characters".


-- 
Jean-Christophe Helary @brandelune
https://mac4translators.blogspot.com
https://sr.ht/~brandelune/omegat-as-a-book/




^ permalink raw reply	[flat|nested] 21+ messages in thread

* Re: non word abbrevs
  2021-11-08  7:18                     ` Jean-Christophe Helary
@ 2021-11-08 23:29                       ` Stefan Monnier via Users list for the GNU Emacs text editor
  0 siblings, 0 replies; 21+ messages in thread
From: Stefan Monnier via Users list for the GNU Emacs text editor @ 2021-11-08 23:29 UTC (permalink / raw)
  To: help-gnu-emacs

> Thank you. I am really just interested in having "proper" text expansions
> like what I have on the OS side. I fail to see the logic of limiting abbrevs
> to "word characters".

Maybe part of the motivation was the performance cost of checking
abbrevs after every key stroke, but I suspect the main issue is avoiding
"false positives":

Say you hit in sequence the three keys `< = >` and you have abbrev rules
for `<=` and for `<=>`, you'd probably not want the first abbrev rule to
apply after you hit `< =` because you'd prefer for Emacs to wait a bit
more and apply the second abbrev rule.

For words, this notion of boundary is fairly standard.  But for other
chars, it's not so clear.
So to lift this restriction we need something more.


        Stefan




^ permalink raw reply	[flat|nested] 21+ messages in thread

end of thread, other threads:[~2021-11-08 23:29 UTC | newest]

Thread overview: 21+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-10-31  5:45 non word abbrevs Jean-Christophe Helary
2021-10-31 19:04 ` Stefan Monnier via Users list for the GNU Emacs text editor
2021-11-01  7:57   ` Jean-Christophe Helary
2021-11-01 10:54     ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-11-01 12:03     ` Stefan Monnier
2021-11-01 12:13       ` Jean-Christophe Helary
2021-11-01 12:43         ` Stefan Monnier via Users list for the GNU Emacs text editor
2021-11-01 13:17           ` Jean-Christophe Helary
2021-11-01 13:49             ` Leo Butler
2021-11-01 14:03             ` tomas
2021-11-01 17:58             ` Stefan Monnier
2021-11-06  8:20         ` Jean-Christophe Helary
2021-11-06 22:32           ` Stefan Monnier
2021-11-07  0:01             ` Jean-Christophe Helary
2021-11-07  3:15               ` Stefan Monnier via Users list for the GNU Emacs text editor
2021-11-07  3:24                 ` Jean-Christophe Helary
2021-11-07  4:11                   ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-11-08  5:36                   ` Kevin Vigouroux via Users list for the GNU Emacs text editor
2021-11-08  7:18                     ` Jean-Christophe Helary
2021-11-08 23:29                       ` Stefan Monnier via Users list for the GNU Emacs text editor
2021-11-07  4:06                 ` Emanuel Berg via Users list for the GNU Emacs text editor

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).