From ef651d13148228be6071da2eb49397ceac5a15d4 Mon Sep 17 00:00:00 2001 From: Stefan Monnier Date: Wed, 10 Oct 2007 19:57:08 +0000 Subject: [PATCH] (let-environment): Remove. Unused. (read-envvar-name): Simplify. (setenv): Remove unused arg `frame'. --- lisp/ChangeLog | 64 +++++++++++++++++++------------------- lisp/env.el | 79 ++++++++--------------------------------------- lisp/font-lock.el | 2 +- 3 files changed, 45 insertions(+), 100 deletions(-) diff --git a/lisp/ChangeLog b/lisp/ChangeLog index d8c31c8139a..0cf312e3871 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,5 +1,11 @@ 2007-10-10 Stefan Monnier + * font-lock.el (lisp-font-lock-keywords-2): Remove let-environment. + + * env.el (let-environment): Remove. Unused. + (read-envvar-name): Simplify. + (setenv): Remove unused arg `frame'. + * help-fns.el (describe-variable): Add missing " " for multiline obsolescence info and missing EOL after global value. @@ -37,54 +43,46 @@ 2007-10-10 Eric S. Raymond - * vc.el (vc-next-action): Completely rewritten; this principal + * vc.el (vc-next-action): Rewrite completely; this principal entry point now operates on a current fileset selected either explicitly via VC-Dired or implicitly by visiting a file buffer, rather than always operating on the file of the current buffer as - in older versions. The rest of the mode has been rewritten to - match. - (with-vc-properties): Rewritten to operate on a file list. + in older versions. Rewrite the rest of the mode to match. + (with-vc-properties): Rewrite to operate on a file list. (with-vc-file): vc-checkin takes a file list argument now. (vc-post-command-functions): This hook now receives a file list. - (vc-do-command): Now takes a either a file or a file list as - argument. + (vc-do-command): Take a either a file or a file list as argument. (vc-deduce-fileset): New function for deducing a file list to operate on. - (vc-next-action-on-file): This function is gone, it is merged into - vc-next-action. - (vc-next-action-dired): This function is gone, it is merged into - vc-next-action. - (vc-register): Adapted to the fact that vc-start-entry now takes a + (vc-next-action-on-file, vc-next-action-dired): Remove. + Merge into vc-next-action. + (vc-register): Adapt to the fact that vc-start-entry now takes a file list. (vc-register-with): New function. - (vc-start-entry): Now takes a file list argument rather than a + (vc-start-entry): Take a file list argument rather than a file argument. - (vc-checkout): Modified to cope with vc-start-entry taking a file - list. - (vc-steal-lock): Modified to cope with with-vc-properties taking a + (vc-checkout): Cope with vc-start-entry taking a file list. + (vc-steal-lock): Cope with with-vc-properties taking a file list. - (vc-checkin): Now takes a file list argument rather than a file - argument. + (vc-checkin): Take a file list argument rather than a file argument. (vc-finish-logentry): Use the filelist passed by vc-start-entry. - (vc-diff-internal): Completely rewritten for filesets. + (vc-diff-internal): Rewrite for filesets. (vc-diff-sentinel): New function, tests whether changes were written into a diff buffer. - (vc-diff): Completely rewritten for filesets. - (vc-version-diff): Completely rewritten for filesets. - (vc-print-log): Now takes a fileset argument. - (vc-revert): Now reverts the entire selected fileset, not just the + (vc-diff): Rewrite for filesets. + (vc-version-diff): Rewrite for filesets. + (vc-print-log): Take a fileset argument. + (vc-revert): Revert the entire selected fileset, not just the current buffer. - (vc-rollback): Now rolls back the entire selected fileset, if + (vc-rollback): Roll back the entire selected fileset, if possible. No longer accepts a prefix argument. - (vc-update): Now merges new changes for the entire selected + (vc-update): Merge new changes for the entire selected fileset, not just the current buffer. - (vc-revert-file): Modified to cope with with-vc-properties taking - a file list. + (vc-revert-file): Cope with with-vc-properties taking a file list. (vc-default-dired-state-info): Add + status suffix if the file is modified. (vc-annotate-warp-version): Use the new diff machinery. - (vc-log-edit): Now takes a file list argument rather than a file - argument. + (vc-log-edit): Take a file list argument rather than a file argument. 2007-10-10 Michael Albinus @@ -108,7 +106,7 @@ (handle-select-window): When autoselecting window set input focus. Restructure. - * frame.el (focus-follows-mouse): Moved to frame.c. + * frame.el (focus-follows-mouse): Move to frame.c. * cus-start.el (all): Add focus-follows-mouse. 2007-10-08 Juanma Barranquero @@ -307,10 +305,10 @@ 2007-10-08 Stefan Monnier - * pcvs.el (cvs-mode-add-change-log-entry-other-window): Use - add-log-buffer-file-name-function rather than bind buffer-file-name, - so we dont end up calling change-log-mode in *cvs* when `fi' is the - ChangeLog file itself. + * pcvs.el (cvs-mode-add-change-log-entry-other-window): + Use add-log-buffer-file-name-function rather than binding + buffer-file-name, so we don't end up calling change-log-mode in *cvs* + when `fi' is the ChangeLog file itself. * outline.el (outline-flag-region): Use front-advance. diff --git a/lisp/env.el b/lisp/env.el index 128228be3db..90d576dc71d 100644 --- a/lisp/env.el +++ b/lisp/env.el @@ -47,15 +47,14 @@ Optional second arg MUSTMATCH, if non-nil, means require existing envvar name. If it is also not t, RET does not exit if it does non-null completion." (completing-read prompt (mapcar (lambda (enventry) - (list (if enable-multibyte-characters - (decode-coding-string - (substring enventry 0 - (string-match "=" enventry)) - locale-coding-system t) - (substring enventry 0 - (string-match "=" enventry))))) + (let ((str (substring enventry 0 + (string-match "=" enventry)))) + (if (multibyte-string-p str) + (decode-coding-string + str locale-coding-system t) + str))) (append process-environment - nil ;;(frame-parameter (frame-with-environment) 'environment) + ;;(frame-environment) )) nil mustmatch nil 'read-envvar-name-history)) @@ -128,7 +127,7 @@ Changes ENV by side-effect, and returns its new value." ;; Fixme: Should the environment be recoded if LC_CTYPE &c is set? -(defun setenv (variable &optional value substitute-env-vars frame) +(defun setenv (variable &optional value substitute-env-vars) "Set the value of the environment variable named VARIABLE to VALUE. VARIABLE should be a string. VALUE is optional; if not provided or nil, the environment variable VARIABLE will be removed. @@ -143,19 +142,11 @@ SUBSTITUTE-ENV-VARS, if non-nil, means to substitute environment variables in VALUE with `substitute-env-vars', which see. This is normally used only for interactive calls. -If optional parameter FRAME is non-nil, this function modifies -only the frame-local value of VARIABLE on FRAME, ignoring -`process-environment'. Note that frames on the same terminal -device usually share their environment, so calling `setenv' on -one of them affects the others as well. - -If FRAME is nil, `setenv' changes the global value of VARIABLE by -modifying `process-environment'. Note that the global value -overrides any frame-local values. - The return value is the new value of VARIABLE, or nil if it was removed from the environment. +This function works by modifying `process-environment'. + As a special case, setting variable `TZ' calls `set-time-zone-rule' as a side-effect." (interactive @@ -188,12 +179,8 @@ a side-effect." (error "Environment variable name `%s' contains `='" variable)) (if (string-equal "TZ" variable) (set-time-zone-rule value)) - (if (null frame) - (setq process-environment (setenv-internal process-environment - variable value t)) - (setq frame (frame-with-environment frame)) - (setq process-environment (setenv-internal process-environment - variable value nil))) + (setq process-environment (setenv-internal process-environment + variable value t)) value) (defun getenv (variable &optional frame) @@ -238,8 +225,7 @@ Non-ASCII characters are encoded according to the initial value of `locale-coding-system', i.e. the elements must normally be decoded for use. See `setenv' and `getenv'." (let* ((env (append process-environment -;; (frame-parameter (frame-with-environment frame) -;; 'environment) + ;; (frame-environment frame) nil)) (scan env) prev seen) @@ -269,45 +255,6 @@ See `setenv' and `getenv'." scan (cdr scan)))) env)) -(defmacro let-environment (varlist &rest body) - "Evaluate BODY with environment variables set according to VARLIST. -The environment variables are then restored to their previous -values. -The value of the last form in BODY is returned. - -Each element of VARLIST is either a string (which variable is -then removed from the environment), or a list (NAME -VALUEFORM) (which sets NAME to the value of VALUEFORM, a string). -All the VALUEFORMs are evaluated before any variables are set." - (declare (indent 2)) - (let ((old-env (make-symbol "old-env")) - (name (make-symbol "name")) - (value (make-symbol "value")) - (entry (make-symbol "entry")) - (frame (make-symbol "frame"))) - `(let ((,frame (selected-frame)) - ,old-env) - ;; Evaluate VALUEFORMs and replace them in VARLIST with their values. - (dolist (,entry ,varlist) - (unless (stringp ,entry) - (if (cdr (cdr ,entry)) - (error "`let-environment' bindings can have only one value-form")) - (setcdr ,entry (eval (cadr ,entry))))) - ;; Set the variables. - (dolist (,entry ,varlist) - (let ((,name (if (stringp ,entry) ,entry (car ,entry))) - (,value (if (consp ,entry) (cdr ,entry)))) - (setq ,old-env (cons (cons ,name (getenv ,name)) ,old-env)) - (setenv ,name ,value))) - (unwind-protect - (progn ,@body) - ;; Restore old values. - (with-selected-frame (if (frame-live-p ,frame) - ,frame - (selected-frame)) - (dolist (,entry ,old-env) - (setenv (car ,entry) (cdr ,entry)))))))) - (provide 'env) ;; arch-tag: b7d6a8f7-bc81-46db-8e39-8d721d4ed0b8 diff --git a/lisp/font-lock.el b/lisp/font-lock.el index be234f607b5..16f9730b1d1 100644 --- a/lisp/font-lock.el +++ b/lisp/font-lock.el @@ -2227,7 +2227,7 @@ other modes in which C preprocessor directives are used. e.g. `asm-mode' and `(;; Control structures. Emacs Lisp forms. (,(concat "(" (regexp-opt - '("cond" "if" "while" "while-no-input" "let" "let*" "let-environment" + '("cond" "if" "while" "while-no-input" "let" "let*" "prog" "progn" "progv" "prog1" "prog2" "prog*" "inline" "lambda" "save-restriction" "save-excursion" "save-window-excursion" "save-selected-window" -- 2.39.5