changeset 2847:01a46a8f1e1b

(fill-region, kill-region, delete-region) (kill-ring-save): Use mark-active as enable condition. (undo): Add an enable condition. Fix up the edit commands. Add fill-region.
author Richard M. Stallman <rms@gnu.org>
date Mon, 17 May 1993 04:45:03 +0000
parents c36e7ad524d3
children 3bcbd1795280
files lisp/menu-bar.el
diffstat 1 files changed, 44 insertions(+), 21 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/menu-bar.el	Mon May 17 04:37:22 1993 +0000
+++ b/lisp/menu-bar.el	Mon May 17 04:45:03 1993 +0000
@@ -45,11 +45,21 @@
 (define-key menu-bar-file-menu [open-file] '("Open File..." . find-file))
 (define-key menu-bar-file-menu [new-frame] '("New Frame" . new-frame))
 
-(define-key menu-bar-edit-menu [clear] '("Clear" . x-delete-primary-selection))
-(define-key menu-bar-edit-menu [paste] '("Paste" . x-yank-clipboard-selection))
-(define-key menu-bar-edit-menu [copy] '("Copy" . x-copy-primary-selection))
-(define-key menu-bar-edit-menu [cut] '("Cut" . x-kill-primary-selection))
-(define-key menu-bar-edit-menu [undo] '("Undo" . advertised-undo))
+(define-key menu-bar-edit-menu [fill] '("Fill" . fill-region))
+(define-key menu-bar-edit-menu [clear] '("Clear" . delete-region))
+(define-key menu-bar-edit-menu [paste] '("Paste" . yank))
+(define-key menu-bar-edit-menu [copy] '("Copy" . kill-ring-save))
+(define-key menu-bar-edit-menu [cut] '("Cut" . kill-region))
+(define-key menu-bar-edit-menu [undo] '("Undo" . undo))
+
+(put 'fill-region 'menu-enable 'mark-active)
+(put 'kill-region 'menu-enable 'mark-active)
+(put 'kill-ring-save 'menu-enable 'mark-active)
+(put 'yank 'menu-enable '(x-selection-exists-p))
+(put 'delete-region 'menu-enable 'mark-active)
+(put 'undo 'menu-enable '(if (eq last-command 'undo)
+			     pending-undo-list
+			   (consp buffer-undo-list)))
 
 (define-key menu-bar-help-menu [emacs-tutorial]
   '("Emacs Tutorial" . help-with-tutorial))
@@ -88,12 +98,6 @@
 (put 'delete-frame 'menu-enable '(cdr (visible-frame-list)))
 (put 'kill-this-buffer 'menu-enable '(kill-this-buffer-enabled-p))
 
-(put 'x-kill-primary-selection 'menu-enable '(x-selection-owner-p))
-(put 'x-copy-primary-selection 'menu-enable '(x-selection-owner-p))
-(put 'x-yank-clipboard-selection 'menu-enable '(x-selection-owner-p))
-(put 'x-delete-primary-selection 'menu-enable
-     '(x-selection-exists-p 'CLIPBOARD))
-
 (put 'advertised-undo 'menu-enable
      '(and (not (eq t buffer-undo-list))
 	   (if (eq last-command 'undo)
@@ -193,18 +197,37 @@
 ;;;	       mode-name
 ;;;	       (or (buffer-file-name) ""))))))
 
-;; Give all existing frames a menu bar.
-;; (Except for minibuffer-only frames.)
-(let ((frames (frame-list)))
-  (while frames
-    (or (eq 'only (cdr (assq 'minibuffer (frame-parameters (car frames)))))
-	(modify-frame-parameters (car frames) '((menu-bar-lines . 1))))
-    (setq frames (cdr frames))))
+(defvar menu-bar-mode nil)
+
+(defun menu-bar-mode (flag)
+  "Toggle display of vertical scroll bars on each frame.
+This command applies to all frames that exist and frames to be
+created in the future.
+With a numeric argument, if the argument is negative,
+turn off scroll bars; otherwise, turn on scroll bars."
+  (interactive "P")
+  (setq menu-bar-mode (if (null flag) (not menu-bar-mode)
+			  (or (not (numberp flag)) (>= flag 0))))
+  (let ((parameter (assq 'menu-bar-lines default-frame-alist)))
+    (if (consp parameter)
+	(setcdr parameter (if menu-bar-mode 1 0))
+      (setq default-frame-alist
+	    (cons (cons 'menu-bar-lines (if menu-bar-mode 1 0))
+		  default-frame-alist))))
+  (let ((frames (frame-list)))
+    (while frames
+      ;; Turn menu bar on or off in existing frames.
+      ;; (Except for minibuffer-only frames.)
+      (or (eq 'only (cdr (assq 'minibuffer (frame-parameters (car frames)))))
+	  (modify-frame-parameters
+	   (car frames)
+	   (list (if menu-bar-mode
+		     '(menu-bar-lines . 1)
+		   '(menu-bar-lines . 0)))))
+      (setq frames (cdr frames)))))
 
 ;; Make frames created from now on have a menu bar.
-(or (assq 'menu-bar-lines default-frame-alist)
-    (setq default-frame-alist
-	  (cons '(menu-bar-lines . 1) default-frame-alist)))
+(menu-bar-mode t)
 
 (provide 'menu-bar)