123456789_123456789_123456789_123456789_123456789_

Class: Process::Status

Relationships & Source Files
Inherits: Object
Defined in: process.c,
process.c

Overview

A Status contains information about a system process.

Thread-local variable $? is initially nil. Some methods assign to it a Status object that represents a system process (either running or terminated):

`ruby -e "exit 99"`
stat = $?       # => #<Process::Status: pid 1262862 exit 99>
stat.class      # => Process::Status
stat.to_i       # => 25344
stat.stopped?   # => false
stat.exited?    # => true
stat.exitstatus # => 99

Instance Attribute Summary

Instance Method Summary

Instance Attribute Details

#coredump?Boolean (readonly)

Returns true if the process generated a coredump when it terminated, false if not.

Not available on all platforms.

[ GitHub ]

  
# File 'process.c', line 1024

static VALUE
pst_wcoredump(VALUE st)
{
#ifdef WCOREDUMP
    int status = PST2INT(st);

    return RBOOL(WCOREDUMP(status));
#else
    return Qfalse;
#endif
}

#exited?Boolean (readonly)

Returns true if the process exited normally (for example using an exit() call or finishing the program), false if not.

[ GitHub ]

  
# File 'process.c', line 958

static VALUE
pst_wifexited(VALUE st)
{
    int status = PST2INT(st);

    return RBOOL(WIFEXITED(status));
}

#signaled?Boolean (readonly)

Returns true if the process terminated because of an uncaught signal, false otherwise.

[ GitHub ]

  
# File 'process.c', line 921

static VALUE
pst_wifsignaled(VALUE st)
{
    int status = PST2INT(st);

    return RBOOL(WIFSIGNALED(status));
}

#stopped?Boolean (readonly)

Returns true if this process is stopped, and if the corresponding Process#wait call had the WUNTRACED flag set, false otherwise.

[ GitHub ]

  
# File 'process.c', line 885

static VALUE
pst_wifstopped(VALUE st)
{
    int status = PST2INT(st);

    return RBOOL(WIFSTOPPED(status));
}

#success?Boolean (readonly)

Returns:

  • true if the process has completed successfully and exited.

  • false if the process has completed unsuccessfully and exited.

  • nil if the process has not exited.

[ GitHub ]

  
# File 'process.c', line 1003

static VALUE
pst_success_p(VALUE st)
{
    int status = PST2INT(st);

    if (!WIFEXITED(status))
        return Qnil;
    return RBOOL(WEXITSTATUS(status) == EXIT_SUCCESS);
}

Instance Method Details

#==(other) ⇒ Boolean

Returns whether the value of #to_i == other:

`cat /nop`
stat = $?                # => #<Process::Status: pid 1170366 exit 1>
sprintf('%x', stat.to_i) # => "100"
stat == 0x100            # => true
[ GitHub ]

  
# File 'process.c', line 868

static VALUE
pst_equal(VALUE st1, VALUE st2)
{
    if (st1 == st2) return Qtrue;
    return rb_equal(pst_to_i(st1), st2);
}

#exitstatusInteger?

Returns the least significant eight bits of the return code of the process if it has exited; nil otherwise:

`exit 99`
$?.exitstatus # => 99
[ GitHub ]

  
# File 'process.c', line 980

static VALUE
pst_wexitstatus(VALUE st)
{
    int status = PST2INT(st);

    if (WIFEXITED(status))
        return INT2NUM(WEXITSTATUS(status));
    return Qnil;
}

#inspectString

Returns a string representation of self:

system("false")
$?.inspect # => "#<Process::Status: pid 1303494 exit 1>"
[ GitHub ]

  
# File 'process.c', line 835

static VALUE
pst_inspect(VALUE st)
{
    rb_pid_t pid;
    int status;
    VALUE str;

    pid = pst_pid(st);
    if (!pid) {
        return rb_sprintf("#<%s: uninitialized>", rb_class2name(CLASS_OF(st)));
    }
    status = PST2INT(st);

    str = rb_sprintf("#<%s: ", rb_class2name(CLASS_OF(st)));
    pst_message(str, pid, status);
    rb_str_cat2(str, ">");
    return str;
}

#pidInteger

Returns the process ID of the process:

system("false")
$?.pid # => 1247002
[ GitHub ]

  
# File 'process.c', line 745

static VALUE
pst_pid_m(VALUE self)
{
    rb_pid_t pid = pst_pid(self);
    return PIDT2NUM(pid);
}

#stopsigInteger?

Returns the number of the signal that caused the process to stop, or nil if the process is not stopped.

[ GitHub ]

  
# File 'process.c', line 902

static VALUE
pst_wstopsig(VALUE st)
{
    int status = PST2INT(st);

    if (WIFSTOPPED(status))
        return INT2NUM(WSTOPSIG(status));
    return Qnil;
}

#termsigInteger?

Returns the number of the signal that caused the process to terminate or nil if the process was not terminated by an uncaught signal.

[ GitHub ]

  
# File 'process.c', line 938

static VALUE
pst_wtermsig(VALUE st)
{
    int status = PST2INT(st);

    if (WIFSIGNALED(status))
        return INT2NUM(WTERMSIG(status));
    return Qnil;
}

#to_iInteger

Returns the system-dependent integer status of self:

`cat /nop`
$?.to_i # => 256
[ GitHub ]

  
# File 'process.c', line 725

static VALUE
pst_to_i(VALUE self)
{
    int status = pst_status(self);
    return RB_INT2NUM(status);
}

#to_sString

Returns a string representation of self:

`cat /nop`
$?.to_s # => "pid 1262141 exit 1"
[ GitHub ]

  
# File 'process.c', line 808

static VALUE
pst_to_s(VALUE st)
{
    rb_pid_t pid;
    int status;
    VALUE str;

    pid = pst_pid(st);
    status = PST2INT(st);

    str = rb_str_buf_new(0);
    pst_message(str, pid, status);
    return str;
}