summaryrefslogtreecommitdiff
path: root/ruby.c
diff options
context:
space:
mode:
authorkosaki <kosaki@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-05-14 10:49:47 +0000
committerkosaki <kosaki@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-05-14 10:49:47 +0000
commit3ad44e0aa18ff335cf110d8da11d92af82e2ad51 (patch)
tree81317d823651a30e88d74fa9aceccbb40402fa9a /ruby.c
parent537a29366961560f926416721cf32eb677a36ec8 (diff)
introduce missing/setproctitle.c
* include/ruby/missing.h: add setproctitle() declaration. * missing/setproctitle.c: added. * configure.in: add check for missing/setproctitle.c. * ruby.c (ruby_process_options): add to call compat_init_setproctitle(). * ruby.c (set_arg0): remove all platform specific code. it's moved to missing/setproctitle.c. * ruby.c (origarg): remove len field. It's no longer used. * ruby.c (get_arglen): removed. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@31565 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ruby.c')
-rw-r--r--ruby.c105
1 files changed, 9 insertions, 96 deletions
diff --git a/ruby.c b/ruby.c
index 3cfa2854c8..0cd847795d 100644
--- a/ruby.c
+++ b/ruby.c
@@ -124,9 +124,6 @@ static void forbid_setid(const char *, struct cmdline_options *);
static struct {
int argc;
char **argv;
-#if !defined(PSTAT_SETCMD) && !defined(HAVE_SETPROCTITLE)
- size_t len;
-#endif
} origarg;
static void
@@ -1680,62 +1677,6 @@ rb_load_file(const char *fname)
return load_file(rb_parser_new(), fname, 0, cmdline_options_init(&opt));
}
-#if !defined(PSTAT_SETCMD) && !defined(HAVE_SETPROCTITLE)
-#if !defined(_WIN32)
-#define USE_ENVSPACE_FOR_ARG0
-#endif
-
-#ifdef USE_ENVSPACE_FOR_ARG0
-extern char **environ;
-#endif
-
-static size_t
-get_arglen(int argc, char **argv)
-{
- char *s = argv[0];
- int i;
-
- if (!argc) return 0;
- s += strlen(s);
- /* See if all the arguments are contiguous in memory */
- for (i = 1; i < argc; i++) {
- if (argv[i] == s + 1) {
- s++;
- s += strlen(s); /* this one is ok too */
- }
- else {
- break;
- }
- }
-#if defined(USE_ENVSPACE_FOR_ARG0)
- if (environ && (s+1 == environ[0])) {
- s++;
- s += strlen(s);
- for (i = 1; environ[i]; i++) {
- if (environ[i] == s + 1) {
- s++;
- s += strlen(s); /* this one is ok too */
- }
- }
-# if defined(HAVE_SETENV) && defined(HAVE_UNSETENV)
- {
- char *t = malloc(s - environ[0] + 1);
- for (i = 0; environ[i]; i++) {
- size_t len = strlen(environ[i]) + 1;
- memcpy(t, environ[i], len);
- environ[i] = t;
- t += len;
- }
- }
-# else
- ruby_setenv("", NULL); /* duplicate environ vars */
-# endif
- }
-#endif
- return s - argv[0];
-}
-#endif
-
static void
set_arg0(VALUE val, ID id)
{
@@ -1747,42 +1688,9 @@ set_arg0(VALUE val, ID id)
StringValue(val);
s = RSTRING_PTR(val);
i = RSTRING_LEN(val);
-#if defined(PSTAT_SETCMD)
- if (i > PST_CLEN) {
- union pstun un;
- char buf[PST_CLEN + 1]; /* PST_CLEN is 64 (HP-UX 11.23) */
- strlcpy(buf, s, sizeof(buf));
- un.pst_command = buf;
- pstat(PSTAT_SETCMD, un, PST_CLEN, 0, 0);
- }
- else {
- union pstun un;
- un.pst_command = s;
- pstat(PSTAT_SETCMD, un, i, 0, 0);
- }
-#elif defined(HAVE_SETPROCTITLE)
- setproctitle("%.*s", (int)i, s);
-#else
-
- if ((size_t)i > origarg.len - origarg.argc) {
- i = (long)(origarg.len - origarg.argc);
- }
-
- memcpy(origarg.argv[0], s, i);
- {
- int j;
- char *t = origarg.argv[0] + i;
- *t = '\0';
+ setproctitle("%.*s", (int)i, s);
- if ((size_t)(i + 1) < origarg.len) {
- memset(t + 1, '\0', origarg.len - i - 1);
- }
- for (j = 1; j < origarg.argc; j++) {
- origarg.argv[j] = t;
- }
- }
-#endif
rb_progname = rb_obj_freeze(rb_external_str_new(s, i));
}
@@ -1891,6 +1799,14 @@ ruby_process_options(int argc, char **argv)
rb_argv0 = rb_str_new4(rb_progname);
rb_gc_register_mark_object(rb_argv0);
iseq = process_options(argc, argv, cmdline_options_init(&opt));
+
+#ifndef HAVE_SETPROCTITLE
+ {
+ extern compat_init_setproctitle(int argc, char *argv[]);
+ compat_init_setproctitle(argc, argv);
+ }
+#endif
+
return (void*)(struct RData*)iseq;
}
@@ -1903,9 +1819,6 @@ ruby_sysinit(int *argc, char ***argv)
#endif
origarg.argc = *argc;
origarg.argv = *argv;
-#if !defined(PSTAT_SETCMD) && !defined(HAVE_SETPROCTITLE)
- origarg.len = get_arglen(origarg.argc, origarg.argv);
-#endif
#if defined(USE_DLN_A_OUT)
dln_argv0 = origarg.argv[0];
#endif