unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* 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).