Page MenuHomePhabricator

Pass an integer to stream_select() for correctness
ClosedPublic

Authored by epriestley on Mar 19 2014, 12:09 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 4:00 PM
Unknown Object (File)
Sat, Jan 18, 2:14 AM
Unknown Object (File)
Wed, Jan 8, 3:19 AM
Unknown Object (File)
Mon, Jan 6, 1:04 PM
Unknown Object (File)
Sun, Jan 5, 6:01 AM
Unknown Object (File)
Sat, Jan 4, 9:16 AM
Unknown Object (File)
Dec 19 2024, 6:04 PM
Unknown Object (File)
Dec 9 2024, 7:33 PM
Subscribers

Details

Summary

Ref T4627. Passing $timeout_sec is slightly more correct here, although there is no change to program behavior.

Test Plan

Used this script to verify that passing 0 and 0.999321 (for example) have the same effect to stream_select():

<?php

$spec = array(
  0 => array('pipe', 'r'),
  1 => array('pipe', 'w'),
  2 => array('pipe', 'w'),
);

$pipes = array();
$proc = proc_open('sleep 30', $spec, $pipes);
list($stdin, $stdout, $stderr) = $pipes;

$read = array($stdout, $stderr);
$write = array();
$except = array();

$select_start = microtime(true);
stream_select($read, $write, $except, 0.999321, 80000);
$select_end = microtime(true);

printf(
  "select() took %d us to return.\n",
  ($select_end - $select_start) * 1000000);

Diff Detail

Repository
rPHU libphutil
Branch
sleepsec
Lint
Lint Passed
Unit
Tests Passed

Event Timeline

epriestley retitled this revision from to Pass an integer to stream_select() for correctness.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: btrahan.
btrahan edited edge metadata.
This revision is now accepted and ready to land.Mar 19 2014, 5:12 PM
epriestley updated this revision to Diff 20335.

Closed by commit rPHUa5fd944af95d (authored by @epriestley).