posix_isatty

(PHP 4, PHP 5, PHP 7, PHP 8)

posix_isattyDosya tanıtıcısı bir etkileşimli uçbirimle ilişkili mi diye bakar

Açıklama

posix_isatty(resource|int $dt): bool

dt dosya tanıtıcısı bir etkileşimli uçbirimle ilişkili mi diye bakar.

Değiştirgeler

dt

resource veya int türünde olması beklenen dosya tanıtıcı. int türünde olanın, doğrudan ilgili sistem çağrısına aktarılabilen bir dosya tanıtıcısı olduğu varsayılır.

Hemen hemen her durumda, resource türünde bir dosya özkaynağı sağlamak istenir.

Dönen Değerler

dt bir uçbirime bağlı açık bir dosya tanıtıcısı ise true, diğer tüm durumlarda false döner.

Ayrıca Bakınız

add a note add a note

User Contributed Notes 2 notes

up
1
hfuecks at phppatterns dot com
17 years ago
Can be useful to determine whether output is being piped elsewhere, for PHP shell scripts, for example;

#!/usr/local/bin/php
<?php
if ( !posix_isatty(STDOUT) ) {
   
fwrite(STDOUT, "Invalid TTY\n");
    exit(
2);
}
fwrite(STDOUT, "Enter you name\n");
$name = fgets(STDIN);
fwrite(STDOUT,"Hello $name\n");
exit(
0);
?>

If this script is like:

script.php > outfile

outfile will contain "Invalid TTY"
up
0
KEINOS
10 months ago
It's quite complicated to understand its movements. But it determines if the file_descriptor is open AND connected to a terminal.

Thus, while receiving data from the STDIN, for example, it will return false.

This move is useful to optionally pipe STDIN to a PHP script, to avoid hanging when nothing is from STDIN.

<?php

// Simply echoes the contents from STDIN if any
// and "no stdin" if not.
echo (posix_isatty(STDIN)) ? 'no stdin' . PHP_EOL : file_get_contents('php://stdin');
?>
To Top