これを行うと、ls /dev/tty*
次の出力が表示されます。
/dev/tty /dev/tty12 /dev/tty17 /dev/tty21 /dev/tty26 /dev/tty30 /dev/tty35 /dev/tty4 /dev/tty44 /dev/tty49 /dev/tty53 /dev/tty58 /dev/tty62 /dev/ttyS0
/dev/tty0 /dev/tty13 /dev/tty18 /dev/tty22 /dev/tty27 /dev/tty31 /dev/tty36 /dev/tty40 /dev/tty45 /dev/tty5 /dev/tty54 /dev/tty59 /dev/tty63 /dev/ttyS1
/dev/tty1 /dev/tty14 /dev/tty19 /dev/tty23 /dev/tty28 /dev/tty32 /dev/tty37 /dev/tty41 /dev/tty46 /dev/tty50 /dev/tty55 /dev/tty6 /dev/tty7 /dev/ttyS2
/dev/tty10 /dev/tty15 /dev/tty2 /dev/tty24 /dev/tty29 /dev/tty33 /dev/tty38 /dev/tty42 /dev/tty47 /dev/tty51 /dev/tty56 /dev/tty60 /dev/tty8 /dev/ttyS3
/dev/tty11 /dev/tty16 /dev/tty20 /dev/tty25 /dev/tty3 /dev/tty34 /dev/tty39 /dev/tty43 /dev/tty48 /dev/tty52 /dev/tty57 /dev/tty61 /dev/tty9
フォーマットが良好で、端末内のすべてのファイルを適切なサイズで表示できます。
ただし、このようにコマンドを実行すると、次のようにwatch -d -n1 'ls /dev/tty*'
表示されます。
Every 1.0s: ls /dev/tty* debian: Wed Jun 30 21:08:06 2021
/dev/tty
/dev/tty0
/dev/tty1
/dev/tty10
/dev/tty11
/dev/tty12
/dev/tty13
/dev/tty14
/dev/tty15
/dev/tty16
/dev/tty17
/dev/tty18
/dev/tty19
/dev/tty2
/dev/tty20
/dev/tty21
...
したがって、出力は縦に表示され、画面に収まりません。なぜですか?この問題をどのように解決できますか?
答え1
なぜですか?
コマンド実行時にwatch
端末に接続されません。つまり、isatty(3)
0 が返されます。次の isatty.c を使用して、コマンドの実行時に端末に接続されていることを確認できます。
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(void)
{
printf("%d\n", isatty(STDOUT_FILENO));
return EXIT_SUCCESS;
}
編む:
gcc isatty.c -o isatty
ターミナルエミュレータで実行:
$ ./isatty
1
時計で実行:
$ watch ./isatty
Every 2.0s: ./isatty darkstar: Wed Jun 30 20:42:51 2021
0
この問題をどのように解決できますか?
watchでlsオプションを使用してください-C
。
watch -d -n1 'ls -C /dev/tty*'
答え2
ls
上記の回答は、TTYが検出されたときと同じ操作を実行するオプションを提供するため、お勧めします。ただし、別のコマンドでこれを行う場合(該当するオプションはありません)、簡単な方法は次のとおりです。
$ watch 'unbuffer ls /dev/tty*'
unbuffer
[1]デフォルトではttyを作成し、それを使用してそれ以外の場合は進行中のバッファリングを停止します。副作用は、実行されているプログラム(この場合ls
)がTTYを確認するため、端末に表示されるものとまったく同じことを実行することです。