Commit | Line | Data |
---|---|---|
6449c898 JB |
1 | ;;; -*-Emacs-Lisp-*- Functions to manipulate environment variables. |
2 | ;;; Copyright Free Software Foundation 1991 | |
3 | ||
4 | ;;; This file is part of GNU Emacs. | |
5 | ||
6 | ;;; GNU Emacs is free software; you can redistribute it and/or modify | |
7 | ;;; it under the terms of the GNU General Public License as published by | |
8 | ;;; the Free Software Foundation; either version 1, or (at your option) | |
9 | ;;; any later version. | |
10 | ||
11 | ;;; GNU Emacs is distributed in the hope that it will be useful, | |
12 | ;;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 | ;;; GNU General Public License for more details. | |
15 | ||
16 | ;;; You should have received a copy of the GNU General Public License | |
17 | ;;; along with GNU Emacs; see the file COPYING. If not, write to | |
18 | ;;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. | |
19 | ||
20 | (provide 'setenv) | |
21 | ||
22 | (defun setenv (variable value) | |
23 | "Set the value of the environment variable named VARIABLE to VALUE. | |
24 | VARIABLE and VALUE should both be strings. | |
25 | This function works by modifying process-environment." | |
26 | (if (string-match "=" variable) | |
27 | (error "name of environment variable contains an '=' character") | |
28 | (let ((pattern (concat "^" (regexp-quote (concat variable "=")))) | |
29 | (scan process-environment)) | |
30 | (while scan | |
31 | (cond | |
32 | ((string-match pattern (car scan)) | |
33 | (setcar scan (concat variable "=" value)) | |
34 | (setq scan nil)) | |
35 | ((null (setq scan (cdr scan))) | |
36 | (setq process-environment | |
37 | (cons (concat variable "=" value) process-environment)))))))) |