(PHP 7 >= 7.2.0)
sapi_windows_vt100_support — Получить или установить поддержку VT100 для заданного потока, свазанного с буфером вывода консоли Windows
$stream
[, bool $enable
] ) : bool
Если параметр enable
опущен, функция возвращает TRUE
или FALSE
в зависимости от того, разрешены или нет управляющие последовательности VT100
для stream
Если параметр enable
задан, функция попытается включить или
выключить функционал VT100 для потока stream
.
В этом случае функция вернет TRUE
или FALSE
в зависимости от успешности выполнения.
При старте, PHP пытается включить VT100 для потоков
STDOUT
и STDERR
. Но если, например,
эти потоки перенаправлены в файл, то поддержка VT100 может не включиться.
Если включена поддержка VT100, то можно использовать управляющие последовательности, так как они известны терминалу. Они позволяют изменять вывод терминала. В Windows эти последовательности известны как "Console Virtual Terminal Sequences".
Эта функция использует реализацию флага
ENABLE_VIRTUAL_TERMINAL_PROCESSING
в Windows 10 API,
следовательно функционал VT100 может быть недоступен в более старых версиях Windows.
stream
Поток, с которым будет работать функция.
enable
Если задано, то должно быть либо TRUE
, либо FALSE
, для включения и отключения VT100 соответственно.
Если параметр enable
опущен, функция возвращает TRUE
или FALSE
в зависимости от того, разрешены или нет управляющие последовательности VT100
Если параметр enable
задан: Возвращает TRUE
в случае успешного завершения или FALSE
в случае возникновения ошибки.
Пример #1 Состояние sapi_windows_vt100_support() по умолчанию
По умолчанию, для STDOUT
и STDERR
поддержка VT100 включена.
php -r "var_export(sapi_windows_vt100_support(STDOUT));echo ' ';var_export(sapi_windows_vt100_support(STDERR));"
Результатом выполнения данного примера будет что-то подобное:
true true
Если поток перенаправлен, то поддержка VT100 будет отключена:
php -r "var_export(sapi_windows_vt100_support(STDOUT));echo ' ';var_export(sapi_windows_vt100_support(STDERR));" 2>NUL
Результатом выполнения данного примера будет что-то подобное:
Пример #2 Изменение состояния с помощью sapi_windows_vt100_support()
Вы не можете включить поддержку VT100 для STDOUT
или STDERR
если эти потоки перенаправлены.
php -r "var_export(sapi_windows_vt100_support(STDOUT, true));echo ' ';var_export(sapi_windows_vt100_support(STDERR, true));" 2>NUL
Результатом выполнения данного примера будет что-то подобное:
true false
Пример #3 Пример использования с поддержкой VT100
<?php
$out = fopen('php://stdout','w');
fwrite($out, 'Just forgot a lettr.');
// Переместить курсор на две позиции назад
fwrite($out, "\033[2D");
// Вставляет один пробел, сдвигая существующий текст вправо -> Просто забыли букву.
fwrite($out, "\033[1@");
fwrite($out, 'e');
?>
Результат выполнения данного примера:
Just forgot a letter.