all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Drew Adams <drew.adams@oracle.com>
To: Yuri Khan <yuri.v.khan@gmail.com>
Cc: "Clément Pit-Claudel" <cpitclaudel@gmail.com>,
	"Paul Eggert" <eggert@cs.ucla.edu>,
	"Emacs developers" <emacs-devel@gnu.org>
Subject: RE: Variable-width font indentation: pasting outside Emacs
Date: Tue, 6 Mar 2018 14:15:06 -0800 (PST)	[thread overview]
Message-ID: <3b3217d9-de2f-4bba-a513-d2f6e714ecbf@default> (raw)
In-Reply-To: <bdef1456-d3b6-4391-8eae-ea5d45bbb13a@default>

Maybe this will clarify my raising of this pasting question:

Today, I copy some code from a Lisp file included in Emacs,
or from an Info node.  Then I modify it, add to it, subtract
from it, etc., to come up with something I think might help
answer a user question on some web site.

It happens sometimes that the code I copied uses tab chars
for indentation.  I use a nil value of `indent-tabs-mode'
for my own use, but the copied code introduces some tab
chars (alas).   I also use a fixed-width font where I'm
working on the copied code.

Depending on the particular context where I might end up
pasting (outside Emacs) my code that now includes some tab
chars, the result might mess up indentation because the
paste context handles tab chars differently.  This is so
even in the common case where the destination expects code
and a fixed-width font and handles such input well.

So today, I'm in the habit of first using `untabify' to
convert such tab chars to SPC.  End of story - great and
easy solution.

In effect, I performed a simple operation before copying.
I could just as well have used a custom command that
copied the text after converting (perhaps a copy of) it
by replacing the tab chars.

Without the simple `untabify' function that Emacs provides,
or something similar (e.g. `query-replace'), I might have
pasted the text with tab chars into the destination, and
then have had to manually clean it up using the inferior
editor of the destination context.  Ugh.

Tab chars are, in effect, variable-width text.  What we
do now to handle tab chars across different environments
can perhaps give us some idea of the problem, and perhaps
of possible solutions, about variable-width text in general.

When using a variable-width font, SPC as well as tab chars
have variable width.  Other chars do too, of course, but
SPC and tab chars are typically used for indentation and
alignment.

Do we have such a simple solution, analogous to using
`untabify' before pasting, for a case where copied code
(or other text) is variable-width?  And where perhaps
the paste destination also handles variable-width text?

Should we?  If we don't, how much trouble will users have
to go through to work around the problem or clean up when
they see crazy results from pasting?

That's the question I'm suggesting we think about.  And
this context is likely more complex, as there are different
kinds of destinations, which may handle variable-width text
differently.  IOW, there may not be a single, simple,
one-size-fits-all `untabify' analog.  We might need more
than one approach.

Yes, it is the user who knows the destination (better than
Emacs knows it, at least).  It is the user whom I would
want to be able to choose how to handle it.

How we can best respond to this question/problem, I don't
know.  I was only asking that we take it into account while
designing an improved-variable-text-indentation-&-alignment
approach for use inside Emacs.  It's not just about how
things look in Emacs.  Text copied from Emacs sometimes
gets pasted outside Emacs.  Let's think about that too;
that's all.



  reply	other threads:[~2018-03-06 22:15 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-03-06 18:21 Variable-width font indentation: pasting outside Emacs Drew Adams
2018-03-06 19:09 ` Yuri Khan
2018-03-06 19:52   ` Drew Adams
2018-03-06 22:15     ` Drew Adams [this message]
2018-03-07  6:28       ` Yuri Khan
2018-03-06 20:21 ` Eli Zaretskii
2018-03-06 20:56 ` Richard Stallman
2018-03-06 21:31   ` Drew Adams

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=3b3217d9-de2f-4bba-a513-d2f6e714ecbf@default \
    --to=drew.adams@oracle.com \
    --cc=cpitclaudel@gmail.com \
    --cc=eggert@cs.ucla.edu \
    --cc=emacs-devel@gnu.org \
    --cc=yuri.v.khan@gmail.com \
    /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.