зеркало из https://github.com/github/ruby.git
process.c: chdir exception message
* process.c (rb_exec_fail): raise with the target directory name when chdir() failed. pointed out by sorah. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@51786 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
06cac6d699
Коммит
be3de529c2
|
@ -1,3 +1,8 @@
|
||||||
|
Mon Sep 7 23:45:28 2015 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
|
* process.c (rb_exec_fail): raise with the target directory name
|
||||||
|
when chdir() failed. pointed out by sorah.
|
||||||
|
|
||||||
Mon Sep 7 22:05:28 2015 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
Mon Sep 7 22:05:28 2015 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
* win32/win32.c (insert): should use plain strdup() instead of
|
* win32/win32.c (insert): should use plain strdup() instead of
|
||||||
|
|
40
process.c
40
process.c
|
@ -2464,6 +2464,26 @@ rb_execarg_parent_end(VALUE execarg_obj)
|
||||||
RB_GC_GUARD(execarg_obj);
|
RB_GC_GUARD(execarg_obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
rb_exec_fail(struct rb_execarg *eargp, int err, const char *errmsg)
|
||||||
|
{
|
||||||
|
if (!errmsg || !*errmsg) return;
|
||||||
|
if (strcmp(errmsg, "chdir") == 0) {
|
||||||
|
rb_sys_fail_str(eargp->chdir_dir);
|
||||||
|
}
|
||||||
|
rb_sys_fail(errmsg);
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
void
|
||||||
|
rb_execarg_fail(VALUE execarg_obj, int err, const char *errmsg)
|
||||||
|
{
|
||||||
|
if (!errmsg || !*errmsg) return;
|
||||||
|
rb_exec_fail(rb_execarg_get(execarg_obj), err, errmsg);
|
||||||
|
RB_GC_GUARD(execarg_obj);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* call-seq:
|
* call-seq:
|
||||||
* exec([env,] command... [,options])
|
* exec([env,] command... [,options])
|
||||||
|
@ -2544,6 +2564,7 @@ rb_f_exec(int argc, const VALUE *argv)
|
||||||
struct rb_execarg *eargp;
|
struct rb_execarg *eargp;
|
||||||
#define CHILD_ERRMSG_BUFLEN 80
|
#define CHILD_ERRMSG_BUFLEN 80
|
||||||
char errmsg[CHILD_ERRMSG_BUFLEN] = { '\0' };
|
char errmsg[CHILD_ERRMSG_BUFLEN] = { '\0' };
|
||||||
|
int err;
|
||||||
|
|
||||||
execarg_obj = rb_execarg_new(argc, argv, TRUE);
|
execarg_obj = rb_execarg_new(argc, argv, TRUE);
|
||||||
eargp = rb_execarg_get(execarg_obj);
|
eargp = rb_execarg_get(execarg_obj);
|
||||||
|
@ -2553,16 +2574,18 @@ rb_f_exec(int argc, const VALUE *argv)
|
||||||
|
|
||||||
rb_exec_async_signal_safe(eargp, errmsg, sizeof(errmsg));
|
rb_exec_async_signal_safe(eargp, errmsg, sizeof(errmsg));
|
||||||
|
|
||||||
preserving_errno(after_exec()); /* restart timer thread */
|
err = errno;
|
||||||
|
after_exec(); /* restart timer thread */
|
||||||
|
|
||||||
|
rb_exec_fail(eargp, err, errmsg);
|
||||||
RB_GC_GUARD(execarg_obj);
|
RB_GC_GUARD(execarg_obj);
|
||||||
if (errmsg[0])
|
rb_syserr_fail_str(err, fail_str);
|
||||||
rb_sys_fail(errmsg);
|
|
||||||
rb_sys_fail_str(fail_str);
|
|
||||||
return Qnil; /* dummy */
|
return Qnil; /* dummy */
|
||||||
}
|
}
|
||||||
|
|
||||||
#define ERRMSG(str) do { if (errmsg && 0 < errmsg_buflen) strlcpy(errmsg, (str), errmsg_buflen); } while (0)
|
#define ERRMSG(str) do { if (errmsg && 0 < errmsg_buflen) strlcpy(errmsg, (str), errmsg_buflen); } while (0)
|
||||||
|
#define ERRMSG1(str, a) do { if (errmsg && 0 < errmsg_buflen) snprintf(errmsg, errmsg_buflen, (str), (a)); } while (0)
|
||||||
|
#define ERRMSG2(str, a, b) do { if (errmsg && 0 < errmsg_buflen) snprintf(errmsg, errmsg_buflen, (str), (a), (b)); } while (0)
|
||||||
|
|
||||||
static int
|
static int
|
||||||
save_redirect_fd(int fd, struct rb_execarg *sargp, char *errmsg, size_t errmsg_buflen)
|
save_redirect_fd(int fd, struct rb_execarg *sargp, char *errmsg, size_t errmsg_buflen)
|
||||||
|
@ -4271,11 +4294,10 @@ rb_f_spawn(int argc, VALUE *argv)
|
||||||
pid = rb_execarg_spawn(execarg_obj, errmsg, sizeof(errmsg));
|
pid = rb_execarg_spawn(execarg_obj, errmsg, sizeof(errmsg));
|
||||||
|
|
||||||
if (pid == -1) {
|
if (pid == -1) {
|
||||||
const char *prog = errmsg;
|
int err = errno;
|
||||||
if (!prog[0]) {
|
rb_exec_fail(eargp, err, errmsg);
|
||||||
rb_sys_fail_str(fail_str);
|
RB_GC_GUARD(execarg_obj);
|
||||||
}
|
rb_syserr_fail_str(err, fail_str);
|
||||||
rb_sys_fail(prog);
|
|
||||||
}
|
}
|
||||||
#if defined(HAVE_WORKING_FORK) || defined(HAVE_SPAWNV)
|
#if defined(HAVE_WORKING_FORK) || defined(HAVE_SPAWNV)
|
||||||
return PIDT2NUM(pid);
|
return PIDT2NUM(pid);
|
||||||
|
|
|
@ -404,9 +404,13 @@ class TestProcess < Test::Unit::TestCase
|
||||||
IO.popen([*PWD, :chdir => d]) {|io|
|
IO.popen([*PWD, :chdir => d]) {|io|
|
||||||
assert_equal(d, io.read.chomp)
|
assert_equal(d, io.read.chomp)
|
||||||
}
|
}
|
||||||
assert_raise(Errno::ENOENT) {
|
assert_raise_with_message(Errno::ENOENT, %r"d/notexist") {
|
||||||
Process.wait Process.spawn(*PWD, :chdir => "d/notexist")
|
Process.wait Process.spawn(*PWD, :chdir => "d/notexist")
|
||||||
}
|
}
|
||||||
|
n = "d/\u{1F37A}"
|
||||||
|
assert_raise_with_message(Errno::ENOENT, /#{n}/) {
|
||||||
|
Process.wait Process.spawn(*PWD, :chdir => n)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче