From: Eric Abrahamsen <eric@ericabrahamsen.net>
To: help-gnu-emacs@gnu.org
Subject: Re: making curly apostrophe part of a word
Date: Wed, 11 Sep 2013 14:38:48 +0800 [thread overview]
Message-ID: <87bo3zc16v.fsf@ericabrahamsen.net> (raw)
In-Reply-To: l0ooj5$4b2$1@ger.gmane.org
Kevin Rodgers <kevin.d.rodgers@gmail.com> writes:
> On 9/6/13 4:37 AM, Andreas Röhler wrote:
>> Am 06.09.2013 11:58, schrieb Eric Abrahamsen:
>>> Andreas Röhler <andreas.roehler@easy-emacs.de> writes:
>>>> Am 06.09.2013 04:47, schrieb Eric Abrahamsen:
>>>>> In certain modes (actually just certain files) I'd like the `’'
>>>>> character to be treated the same as a `'' character with respect to word
>>>>> movement: ie I'd like M-f to skip over the entirety of both "don't" and
>>>>> "don’t". I'm editing externally-created files, and don't have the
>>>>> liberty of changing this.
>>>>>
>>>>> I thought this would do it:
>>>>>
>>>>> (modify-syntax-entry ?’ "w")
>>>>>
>>>>
>>>> Works for me in current buffer. `forward-word' passes as expected.
>>>> Which command fails for you?
>>>
>>> `forward-word' fails... Hang on, I'll do the emacs -Q dance and see
>>> what's going on. This was originally in an html-mode buffer, but I don't
>>> see why that would matter as long as no third argument was passed to
>>> `modify-syntax-entry'.
>>
>> It affects the current buffer only, not the mode in other buffers when done that
>> way - maybe that's it?
>
> Not according to its doc string:
>
> The syntax is changed only for table SYNTAX-TABLE, which defaults to
> the current buffer's syntax table.
>
> Different buffers in the same major mode usually share the same syntax table.
Ugh, this is very weird. I started emacs -Q (emacs-version "24.3.1"),
went into an empty buffer and turned it into text mode, then put in
these lines:
can’t
bug&bear
bug©bear
All three of "’", "&", and "©" originally act as word boundaries:
invoking M-f from the front of the word and M-b from the back stops once
_before_ the symbol. The next invocation goes to the next whitespace.
Then for each of those three symbols I call (modify-syntax-entry ?[char]
"w"). Now "&" and "©" behave as expected: M-f and M-b jump all the way
across.
But "’" is different: after modifying its syntax, word-movement commands
stop _twice_, once on each side of the character, before moving to the
other end of the word.
I wonder if I've somehow added "w" to its existing syntax definition,
without "clearing" the existing definition, and that's why it's behaving
strangely?
No idea,
E
prev parent reply other threads:[~2013-09-11 6:38 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-09-06 2:47 making curly apostrophe part of a word Eric Abrahamsen
2013-09-06 9:51 ` Andreas Röhler
2013-09-06 9:58 ` Eric Abrahamsen
2013-09-06 10:37 ` Andreas Röhler
2013-09-11 3:39 ` Kevin Rodgers
2013-09-11 6:38 ` Eric Abrahamsen [this message]
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/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87bo3zc16v.fsf@ericabrahamsen.net \
--to=eric@ericabrahamsen.net \
--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.
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).