好吧,这是一个古怪的答案,但这也是一个古怪的问题,所以至少它们是匹配的。您可以使用mkfifo 创建一个命名管道,然后设置一个无限循环,从命名管道读取文件并将它们通过管道传输到pbcopy(或xsel、xclip 等)。
1. 在不在屏幕会话中的终端中(仅运行一次):
/usr/bin/mkfifo /tmp/pbcopy.pipe
while true; do /bin/cat /tmp/pbcopy.pipe | /usr/bin/pbcopy; done
你可能想把它变成一个 shell 脚本,比如(这可能应该更健壮)
#!/bin/bash
if [[ -e /tmp/pbcopy.pipe ]]; then
echo "it looks like I am already running"
echo "remove /tmp/pbcopy.pipe if you are certain I am not"
exit 1
fi
while true; do
/bin/cat /tmp/pbcopy.pipe | /usr/bin/pbcopy
done
您可以将其命名为 pbcopy_server.sh,使其可执行 (chmod a+x pbcopy_server.sh) 并放在路径中的某个位置,这样您就可以在第一次启动机器时说 nohup pbcopy_server.sh &。
2. 在任何其他终端(包括屏幕会话中的终端)中,您现在可以 cat 文件(或将程序的输出重定向到 /tmp/pbcopy.pipe,文本将出现在剪贴板中。
cat file > /tmp/pbcopy.pipe
df -h > /tmp/pbcopy.pipe
3.为了让您看起来像是在呼叫真正的pbcopy,您可以使用一些东西来为您拨打/tmp/pbcopy.pipe。
3a.使用zsh函数:
function pbcopy() { cat > /tmp/pbcopy.pipe }
3b. 或者创建一个名为pbcopy 的Perl 脚本,并将其放在PATH 中比/usr/bin 更早的目录中:
#!/usr/bin/perl
use strict;
use warnings;
open my $out, ">", "/tmp/pbcopy.pipe"
or die "could not open pipe to pbcopy: $!\n";
print $out $_ while <>;