From: Paul Eggert Date: Sat, 2 Nov 2013 02:11:37 +0000 (-0700) Subject: * emacs.c (original_pwd): Remove global var by making it local. X-Git-Tag: emacs-24.3.90~173^2^2~42^2~45^2~387^2~1031 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=a90e5a330c68cd42347083c21a6d495bbff7b547;p=emacs.git * emacs.c (original_pwd): Remove global var by making it local. (init_cmdargs): New arg ORIGINAL_PWD; caller changed. --- diff --git a/src/ChangeLog b/src/ChangeLog index 8186e220d7d..2191cb5064e 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,8 @@ +2013-11-02 Paul Eggert + + * emacs.c (original_pwd): Remove global var by making it local. + (init_cmdargs): New arg ORIGINAL_PWD; caller changed. + 2013-11-01 Jan Djärv * xfaces.c: Declare color_distance. diff --git a/src/emacs.c b/src/emacs.c index 92b52f1cea6..ed93067d1fd 100644 --- a/src/emacs.c +++ b/src/emacs.c @@ -202,9 +202,6 @@ static char *daemon_name; startup. */ int daemon_pipe[2]; -/* If we use --chdir, this records the original directory. */ -char *original_pwd; - /* Save argv and argc. */ char **initial_argv; int initial_argc; @@ -386,7 +383,7 @@ terminate_due_to_signal (int sig, int backtrace_limit) /* Code for dealing with Lisp access to the Unix command line. */ static void -init_cmdargs (int argc, char **argv, int skip_args) +init_cmdargs (int argc, char **argv, int skip_args, char *original_pwd) { register int i; Lisp_Object name, dir, handler; @@ -705,6 +702,9 @@ main (int argc, char **argv) #endif char *ch_to_dir; + /* If we use --chdir, this records the original directory. */ + char *original_pwd = 0; + #if GC_MARK_STACK stack_base = &dummy; #endif @@ -794,7 +794,7 @@ main (int argc, char **argv) if (argmatch (argv, argc, "-chdir", "--chdir", 4, &ch_to_dir, &skip_args)) { original_pwd = get_current_dir_name (); - if (chdir (ch_to_dir) == -1) + if (chdir (ch_to_dir) != 0) { fprintf (stderr, "%s: Can't chdir to %s: %s\n", argv[0], ch_to_dir, strerror (errno)); @@ -1330,7 +1330,9 @@ Using an Emacs configured with --with-x-toolkit=lucid does not have this problem init_buffer (); /* Init default directory of main buffer. */ init_callproc_1 (); /* Must precede init_cmdargs and init_sys_modes. */ - init_cmdargs (argc, argv, skip_args); /* Must precede init_lread. */ + + /* Must precede init_lread. */ + init_cmdargs (argc, argv, skip_args, original_pwd); if (initialized) {