* Toggle EOL
[not found] <F102hm4mRK4dGDNhxKL00000226@hotmail.com>
@ 2002-06-28 17:07 ` Stefan Monnier
2002-06-28 20:01 ` Jan D.
2002-06-29 22:21 ` Richard Stallman
2002-06-29 8:41 ` Profiling font-lock in xemacs Richard Stallman
1 sibling, 2 replies; 5+ messages in thread
From: Stefan Monnier @ 2002-06-28 17:07 UTC (permalink / raw)
I think that the EOL information in the mode-line should be
better separated from the coding-system info. The patch below
gives it its own help-echo and its own keymap (mouse-3 switches
between the three different possible EOL).
Any comment/objection ?
Stefan
Index: bindings.el
===================================================================
RCS file: /cvsroot/emacs/emacs/lisp/bindings.el,v
retrieving revision 1.100
diff -u -u -b -r1.100 bindings.el
--- bindings.el 16 Apr 2002 14:55:13 -0000 1.100
+++ bindings.el 28 Jun 2002 17:01:15 -0000
@@ -135,6 +135,36 @@
"Local keymap for the coding-system part of the mode line.")
+(defvar mode-line-eol-map
+ (let ((map (make-sparse-keymap)))
+ (define-key map [mode-line mouse-3]
+ (lambda ()
+ (interactive)
+ (let ((eol (coding-system-eol-type buffer-file-coding-system)))
+ (set-buffer-file-coding-system
+ (cond ((eq eol 0) 'dos) ((eq eol 1) 'mac) (t 'unix))))))
+ (purecopy map))
+ "Local keymap for the `coding-system-eol-type' part of the mode line.")
+
+(defvar mode-line-eol-desc-cache nil)
+
+(defun mode-line-eol-desc ()
+ (let* ((eol (coding-system-eol-type buffer-file-coding-system))
+ (mnemonic (coding-system-eol-type-mnemonic buffer-file-coding-system))
+ (desc (assq eol mode-line-eol-desc-cache)))
+ (if (and desc (eq (cadr desc) mnemonic))
+ (cddr desc)
+ (setq desc
+ (propertize
+ mnemonic
+ 'help-echo (format "%s end-of-line; mouse-3 to change"
+ (if (eq eol 0) "Unix-style LF"
+ (if (eq eol 1) "Dos-style CRLF"
+ (if (eq eol 2) "Mac-style CR" "Undecided"))))
+ 'keymap mode-line-eol-map))
+ (push (cons eol (cons mnemonic desc)) mode-line-eol-desc-cache)
+ desc)))
+
(defvar mode-line-mule-info
`(""
(current-input-method
@@ -145,7 +175,7 @@
". mouse-2: disable, mouse-3: describe")
local-map ,mode-line-input-method-map))
,(propertize
- "%Z"
+ "%z"
'help-echo
#'(lambda (window object point)
(with-current-buffer (window-buffer window)
@@ -157,16 +187,17 @@
" buffer; mouse-3: describe coding system")
(concat "Unibyte " (symbol-name buffer-file-coding-system)
" buffer")))))
- 'local-map mode-line-coding-system-map))
+ 'local-map mode-line-coding-system-map)
+ (:eval (mode-line-eol-desc))))
"Mode-line control for displaying information of multilingual environment.
Normally it displays current input method (if any activated) and
mnemonics of the following coding systems:
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Toggle EOL
2002-06-28 17:07 ` Toggle EOL Stefan Monnier
@ 2002-06-28 20:01 ` Jan D.
2002-06-28 20:42 ` Stefan Monnier
2002-06-29 22:21 ` Richard Stallman
1 sibling, 1 reply; 5+ messages in thread
From: Jan D. @ 2002-06-28 20:01 UTC (permalink / raw)
Cc: emacs-devel
>
> I think that the EOL information in the mode-line should be
> better separated from the coding-system info. The patch below
> gives it its own help-echo and its own keymap (mouse-3 switches
> between the three different possible EOL).
>
> Any comment/objection ?
I like it. But is the patch correct? My patch program complained
that the last hunk was corrupted. And I think this line:
+ (:eval (mode-line-eol-desc))))
should end in 3 ), not 4.
But the concept is great, I've had some problems explaining coding
systems at work, this makes things easier.
Jan D.
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Toggle EOL
2002-06-28 20:01 ` Jan D.
@ 2002-06-28 20:42 ` Stefan Monnier
0 siblings, 0 replies; 5+ messages in thread
From: Stefan Monnier @ 2002-06-28 20:42 UTC (permalink / raw)
Cc: Stefan Monnier, emacs-devel
> >
> > I think that the EOL information in the mode-line should be
> > better separated from the coding-system info. The patch below
> > gives it its own help-echo and its own keymap (mouse-3 switches
> > between the three different possible EOL).
> >
> > Any comment/objection ?
>
> I like it. But is the patch correct? My patch program complained
> that the last hunk was corrupted. And I think this line:
> + (:eval (mode-line-eol-desc))))
Yes, there was a typo and I fiddle with the patch by hand :-(
This one should work better,
Stefan
diff -u -u -b -r1.100 bindings.el
--- bindings.el 16 Apr 2002 14:55:13 -0000 1.100
+++ bindings.el 28 Jun 2002 20:41:28 -0000
@@ -135,6 +135,38 @@
"Local keymap for the coding-system part of the mode line.")
+(defvar mode-line-eol-map
+ (let ((map (make-sparse-keymap)))
+ (define-key map [mode-line mouse-3]
+ (lambda ()
+ (interactive)
+ (let ((eol (coding-system-eol-type buffer-file-coding-system)))
+ (set-buffer-file-coding-system
+ (cond ((eq eol 0) 'dos) ((eq eol 1) 'mac) (t 'unix))))))
+ (purecopy map))
+ "Local keymap for the `coding-system-eol-type' part of the mode line.")
+
+(defvar mode-line-eol-desc-cache nil)
+
+(defun mode-line-eol-desc ()
+ (let* ((eol (coding-system-eol-type buffer-file-coding-system))
+ (mnemonic (coding-system-eol-type-mnemonic buffer-file-coding-system))
+ (desc (assq eol mode-line-eol-desc-cache)))
+ (if (and desc (eq (cadr desc) mnemonic))
+ (cddr desc)
+ (if desc (setq mode-line-eol-desc-cache nil)) ;Flush the cache if stale.
+ (setq desc
+ (propertize
+ mnemonic
+ 'help-echo (format "%s end-of-line; mouse-3 to cycle"
+ (if (eq eol 0) "Unix-style LF"
+ (if (eq eol 1) "Dos-style CRLF"
+ (if (eq eol 2) "Mac-style CR"
+ "Undecided"))))
+ 'keymap mode-line-eol-map))
+ (push (cons eol (cons mnemonic desc)) mode-line-eol-desc-cache)
+ desc)))
+
(defvar mode-line-mule-info
`(""
(current-input-method
@@ -145,7 +177,7 @@
". mouse-2: disable, mouse-3: describe")
local-map ,mode-line-input-method-map))
,(propertize
- "%Z"
+ "%z"
'help-echo
#'(lambda (window object point)
(with-current-buffer (window-buffer window)
@@ -157,7 +189,8 @@
" buffer; mouse-3: describe coding system")
(concat "Unibyte " (symbol-name buffer-file-coding-system)
" buffer")))))
- 'local-map mode-line-coding-system-map))
+ 'local-map mode-line-coding-system-map)
+ (:eval (mode-line-eol-desc)))
"Mode-line control for displaying information of multilingual environment.
Normally it displays current input method (if any activated) and
mnemonics of the following coding systems:
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Profiling font-lock in xemacs
[not found] <F102hm4mRK4dGDNhxKL00000226@hotmail.com>
2002-06-28 17:07 ` Toggle EOL Stefan Monnier
@ 2002-06-29 8:41 ` Richard Stallman
1 sibling, 0 replies; 5+ messages in thread
From: Richard Stallman @ 2002-06-29 8:41 UTC (permalink / raw)
Cc: monnier+gnu/emacs, ben, bws, xemacs-design, emacs-devel
It would be better not to have a delay of even .25 second in handling
C-g. It ought to respond crisply.
If the delay were made smaller, eventually it would be insignificant.
I don't know at what point that is reached.
Currently on some systems C-g handling can involve a delay of up to 1
second, the wait for "polling for input". That's because when it was
implemented there was no better facility to use than `alarm'.
Nowadays I gather there is one; we should change the polling interval
to something shorter than a second.
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Toggle EOL
2002-06-28 17:07 ` Toggle EOL Stefan Monnier
2002-06-28 20:01 ` Jan D.
@ 2002-06-29 22:21 ` Richard Stallman
1 sibling, 0 replies; 5+ messages in thread
From: Richard Stallman @ 2002-06-29 22:21 UTC (permalink / raw)
Cc: emacs-devel
The general idea looks good.
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2002-06-29 22:21 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <F102hm4mRK4dGDNhxKL00000226@hotmail.com>
2002-06-28 17:07 ` Toggle EOL Stefan Monnier
2002-06-28 20:01 ` Jan D.
2002-06-28 20:42 ` Stefan Monnier
2002-06-29 22:21 ` Richard Stallman
2002-06-29 8:41 ` Profiling font-lock in xemacs Richard Stallman
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
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).