Class: Process::Status
Overview
*******************************************************************
<code>Process::Status</code> encapsulates the information on the
status of a running or terminated system process. The built-in
variable <code>$?</code> is either +nil+ or a
<code>Process::Status</code> object.
fork { exit 99 } #=> 26557
Process.wait #=> 26557
$?.class #=> Process::Status
$?.to_i #=> 25344
$? >> 8 #=> 99
$?.stopped? #=> false
$?.exited? #=> true
$?.exitstatus #=> 99
Posix systems record information on processes using a 16-bit
integer. The lower bits record the process status (stopped,
exited, signaled) and the upper bits possibly contain additional
information (for example the program's return code in the case of
exited processes). Pre Ruby 1.8, these bits were exposed directly
to the Ruby program. Ruby now encapsulates these in a
<code>Process::Status</code> object. To maximize compatibility,
however, these objects retain a bit-oriented interface. In the
descriptions that follow, when we talk about the integer value of
_stat_, we're referring to this 16 bit value.
Instance Method Summary collapse
-
#&(num) ⇒ Fixnum
Logical AND of the bits in stat with num.
-
#==(other) ⇒ Boolean
Returns
trueif the integer value of stat equals other. -
#>>(num) ⇒ Fixnum
Shift the bits in stat right num places.
-
#coredump? ⇒ Boolean
Returns
trueif stat generated a coredump when it terminated. -
#exited? ⇒ Boolean
Returns
trueif stat exited normally (for example using anexit()call or finishing the program). -
#exitstatus ⇒ Fixnum?
Returns the least significant eight bits of the return code of stat.
-
#inspect ⇒ String
Override the inspection method.
-
#pid ⇒ Fixnum
Returns the process ID that this status object represents.
-
#signaled? ⇒ Boolean
Returns
trueif stat terminated because of an uncaught signal. -
#stopped? ⇒ Boolean
Returns
trueif this process is stopped. -
#stopsig ⇒ Fixnum?
Returns the number of the signal that caused stat to stop (or
nilif self is not stopped). -
#success? ⇒ true, ...
Returns
trueif stat is successful,falseif not. -
#termsig ⇒ Fixnum?
Returns the number of the signal that caused stat to terminate (or
nilif self was not terminated by an uncaught signal). -
#to_i ⇒ Object
Returns the bits in stat as a
Fixnum. -
#to_s ⇒ String
Show pid and exit status as a string.
Instance Method Details
#&(num) ⇒ Fixnum
Logical AND of the bits in stat with num.
fork { exit 0x37 }
Process.wait
sprintf('%04x', $?.to_i) #=> "3700"
sprintf('%04x', $? & 0x1e00) #=> "1600"
501 502 503 504 505 506 507 |
# File 'process.c', line 501 static VALUE pst_bitand(VALUE st1, VALUE st2) { int status = PST2INT(st1) & NUM2INT(st2); return INT2NUM(status); } |
#==(other) ⇒ Boolean
Returns true if the integer value of stat equals other.
481 482 483 484 485 486 |
# File 'process.c', line 481 static VALUE pst_equal(VALUE st1, VALUE st2) { if (st1 == st2) return Qtrue; return rb_equal(pst_to_i(st1), st2); } |
#>>(num) ⇒ Fixnum
Shift the bits in stat right num places.
fork { exit 99 } #=> 26563
Process.wait #=> 26563
$?.to_i #=> 25344
$? >> 8 #=> 99
522 523 524 525 526 527 528 |
# File 'process.c', line 522 static VALUE pst_rshift(VALUE st1, VALUE st2) { int status = PST2INT(st1) >> NUM2INT(st2); return INT2NUM(status); } |
#coredump? ⇒ Boolean
Returns true if stat generated a coredump when it terminated. Not available on all platforms.
689 690 691 692 693 694 695 696 697 698 699 700 701 702 |
# File 'process.c', line 689 static VALUE pst_wcoredump(VALUE st) { #ifdef WCOREDUMP int status = PST2INT(st); if (WCOREDUMP(status)) return Qtrue; else return Qfalse; #else return Qfalse; #endif } |
#exited? ⇒ Boolean
Returns true if stat exited normally (for example using an exit() call or finishing the program).
620 621 622 623 624 625 626 627 628 629 |
# File 'process.c', line 620 static VALUE pst_wifexited(VALUE st) { int status = PST2INT(st); if (WIFEXITED(status)) return Qtrue; else return Qfalse; } |
#exitstatus ⇒ Fixnum?
Returns the least significant eight bits of the return code of stat. Only available if exited? is true.
fork { } #=> 26572
Process.wait #=> 26572
$?.exited? #=> true
$?.exitstatus #=> 0
fork { exit 99 } #=> 26573
Process.wait #=> 26573
$?.exited? #=> true
$?.exitstatus #=> 99
651 652 653 654 655 656 657 658 659 |
# File 'process.c', line 651 static VALUE pst_wexitstatus(VALUE st) { int status = PST2INT(st); if (WIFEXITED(status)) return INT2NUM(WEXITSTATUS(status)); return Qnil; } |
#inspect ⇒ String
Override the inspection method.
system("false")
p $?.inspect #=> "#<Process::Status: pid 12861 exit 1>"
452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 |
# File 'process.c', line 452 static VALUE pst_inspect(VALUE st) { rb_pid_t pid; int status; VALUE vpid, str; vpid = pst_pid(st); if (NIL_P(vpid)) { return rb_sprintf("#<%s: uninitialized>", rb_class2name(CLASS_OF(st))); } pid = NUM2PIDT(vpid); status = PST2INT(st); str = rb_sprintf("#<%s: ", rb_class2name(CLASS_OF(st))); (str, pid, status); rb_str_cat2(str, ">"); return str; } |
#pid ⇒ Fixnum
Returns the process ID that this status object represents.
fork { exit } #=> 26569
Process.wait #=> 26569
$?.pid #=> 26569
373 374 375 376 377 |
# File 'process.c', line 373 static VALUE pst_pid(VALUE st) { return rb_attr_get(st, rb_intern("pid")); } |
#signaled? ⇒ Boolean
Returns true if stat terminated because of an uncaught signal.
579 580 581 582 583 584 585 586 587 588 |
# File 'process.c', line 579 static VALUE pst_wifsignaled(VALUE st) { int status = PST2INT(st); if (WIFSIGNALED(status)) return Qtrue; else return Qfalse; } |
#stopped? ⇒ Boolean
Returns true if this process is stopped. This is only returned if the corresponding wait call had the WUNTRACED flag set.
540 541 542 543 544 545 546 547 548 549 |
# File 'process.c', line 540 static VALUE pst_wifstopped(VALUE st) { int status = PST2INT(st); if (WIFSTOPPED(status)) return Qtrue; else return Qfalse; } |
#stopsig ⇒ Fixnum?
Returns the number of the signal that caused stat to stop (or nil if self is not stopped).
560 561 562 563 564 565 566 567 568 |
# File 'process.c', line 560 static VALUE pst_wstopsig(VALUE st) { int status = PST2INT(st); if (WIFSTOPPED(status)) return INT2NUM(WSTOPSIG(status)); return Qnil; } |
#success? ⇒ true, ...
Returns true if stat is successful, false if not. Returns nil if exited? is not true.
670 671 672 673 674 675 676 677 678 |
# File 'process.c', line 670 static VALUE pst_success_p(VALUE st) { int status = PST2INT(st); if (!WIFEXITED(status)) return Qnil; return WEXITSTATUS(status) == EXIT_SUCCESS ? Qtrue : Qfalse; } |
#termsig ⇒ Fixnum?
Returns the number of the signal that caused stat to terminate (or nil if self was not terminated by an uncaught signal).
600 601 602 603 604 605 606 607 608 |
# File 'process.c', line 600 static VALUE pst_wtermsig(VALUE st) { int status = PST2INT(st); if (WIFSIGNALED(status)) return INT2NUM(WTERMSIG(status)); return Qnil; } |
#to_i ⇒ Fixnum #to_int ⇒ Fixnum
Returns the bits in stat as a Fixnum. Poking around in these bits is platform dependent.
fork { exit 0xab } #=> 26566
Process.wait #=> 26566
sprintf('%04x', $?.to_i) #=> "ab00"
354 355 356 357 358 |
# File 'process.c', line 354 static VALUE pst_to_i(VALUE st) { return rb_iv_get(st, "status"); } |
#to_s ⇒ String
Show pid and exit status as a string.
system("false")
p $?.to_s #=> "pid 12766 exit 1"
425 426 427 428 429 430 431 432 433 434 435 436 437 438 |
# File 'process.c', line 425 static VALUE pst_to_s(VALUE st) { rb_pid_t pid; int status; VALUE str; pid = NUM2PIDT(pst_pid(st)); status = PST2INT(st); str = rb_str_buf_new(0); (str, pid, status); return str; } |