[前][次][番号順一覧][スレッド一覧]

ruby-changes:18641

From: usa <ko1@a...>
Date: Thu, 27 Jan 2011 15:21:45 +0900 (JST)
Subject: [ruby-changes:18641] Ruby:r30665 (trunk): * win32/win32.c (rb_w32_spawn, rb_w32_aspawn): fixed previous commit. sorry.

usa	2011-01-27 15:21:40 +0900 (Thu, 27 Jan 2011)

  New Revision: 30665

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=30665

  Log:
    * win32/win32.c (rb_w32_spawn, rb_w32_aspawn): fixed previous commit. sorry.

  Modified files:
    trunk/win32/win32.c

Index: win32/win32.c
===================================================================
--- win32/win32.c	(revision 30664)
+++ win32/win32.c	(revision 30665)
@@ -1113,7 +1113,7 @@
     const char *shell = NULL;
     WCHAR *wcmd, *wshell;
     rb_pid_t ret;
-    VALUE tmp = Qnil;
+    VALUE v = 0;
 
     if (check_spawn_mode(mode)) return -1;
 
@@ -1131,19 +1131,17 @@
 	int nt;
 	while (ISSPACE(*cmd)) cmd++;
 	if ((shell = getenv("RUBYSHELL")) && (redir = has_redirection(cmd))) {
-	    ALLOCV(tmp, strlen(shell) + strlen(cmd) + sizeof(" -c ") + 2);
-	    sprintf(RSTRING_PTR(tmp), "%s -c \"%s\"", shell, cmd);
-	    cmd = RSTRING_PTR(tmp);
+	    char *tmp = ALLOCV(v, strlen(shell) + strlen(cmd) + sizeof(" -c ") + 2);
+	    sprintf(tmp, "%s -c \"%s\"", shell, cmd);
+	    cmd = tmp;
 	}
 	else if ((shell = getenv("COMSPEC")) &&
 		 (nt = !is_command_com(shell),
 		  (redir < 0 ? has_redirection(cmd) : redir) ||
 		  is_internal_cmd(cmd, nt))) {
-	    ALLOCV(tmp,
-		   strlen(shell) + strlen(cmd) + sizeof(" /c ") + (nt ? 2 : 0));
-	    sprintf(RSTRING_PTR(tmp),
-		    nt ? "%s /c \"%s\"" : "%s /c %s", shell, cmd);
-	    cmd = RSTRING_PTR(tmp);
+	    char *tmp = ALLOCV(v, strlen(shell) + strlen(cmd) + sizeof(" /c ") + (nt ? 2 : 0));
+	    sprintf(tmp, nt ? "%s /c \"%s\"" : "%s /c %s", shell, cmd);
+	    cmd = tmp;
 	}
 	else {
 	    int len = 0, quote = (*cmd == '"') ? '"' : (*cmd == '\'') ? '\'' : 0;
@@ -1184,8 +1182,7 @@
 		if (p) translate_char(p, '/', '\\');
 		if (is_batch(shell)) {
 		    int alen = strlen(prog);
-		    ALLOCV(tmp, len + alen + (quote ? 2 : 0) + 1);
-		    cmd = p = RSTRING_PTR(tmp);
+		    cmd = p = ALLOCV(v, len + alen + (quote ? 2 : 0) + 1);
 		    if (quote) *p++ = '"';
 		    memcpy(p, shell, len);
 		    p += len;
@@ -1199,7 +1196,7 @@
 
     /* assume ACP */
     wcmd = cmd ? acp_to_wstr(cmd, NULL) : NULL;
-    if (!NIL_P(tmp)) ALLOCV_END(tmp);
+    if (v) ALLOCV_END(v);
     wshell = shell ? acp_to_wstr(shell, NULL) : NULL;
 
     ret = child_result(CreateChild(wcmd, wshell, NULL, NULL, NULL, NULL), mode);
@@ -1218,7 +1215,7 @@
     char *cmd, fbuf[MAXPATHLEN];
     WCHAR *wcmd, *wprog;
     rb_pid_t ret;
-    VALUE tmp = Qnil;
+    VALUE v = 0;
 
     if (check_spawn_mode(mode)) return -1;
 
@@ -1251,8 +1248,7 @@
 	if (c_switch) len += 3;
 	else ++argv;
 	if (argv[0]) len += join_argv(NULL, argv, ntcmd);
-	ALLOCV(tmp, len);
-	cmd = RSTRING_PTR(tmp);
+	cmd = ALLOCV(v, len);
 	join_argv(cmd, progs, ntcmd);
 	if (c_switch) strlcat(cmd, " /c", len);
 	if (argv[0]) join_argv(cmd + strlcat(cmd, " ", len), argv, ntcmd);
@@ -1260,14 +1256,13 @@
     }
     else {
 	len = join_argv(NULL, argv, FALSE);
-	ALLOCV(tmp, len);
-	cmd = RSTRING_PTR(tmp);
+	cmd = ALLOCV(v, len);
 	join_argv(cmd, argv, FALSE);
     }
 
     /* assume ACP */
     wcmd = cmd ? acp_to_wstr(cmd, NULL) : NULL;
-    if (!NIL_P(tmp)) ALLOCV_END(tmp);
+    if (v) ALLOCV_END(v);
     wprog = prog ? acp_to_wstr(prog, NULL) : NULL;
 
     ret = child_result(CreateChild(wcmd, wprog, NULL, NULL, NULL, NULL), mode);

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]