打印fifo内容并退出

时间:2009-05-14 21:04:45

标签: linux shell command-line named-pipes

我需要将fifo(命名管道)的内容打印到标准输出 我可以使用命令:

cat fifo

问题是cat没有返回。它一直在运行,等待来自fifo的更多内容。但我知道暂时不会有更多的内容,所以我只想打印出可用的内容。

是否有一个命令只打印可用内容并退出??

修改
在fifo的一端,有一个进程每隔一段时间写入不同命令的输出。这个过程是永久性的,所以不会有EOF。

2 个答案:

答案 0 :(得分:2)

当您无法发送EOF时,您可以使用“非阻挡猫”。我已经包含了一个(经过测试的)C版本,我发现here(当然,这归功于原作者)。神奇的是fcntl(STDIN_FILENO, F_SETFL, O_NONBLOCK).

此非阻塞cat的第一个参数是您在再次退出之前要等待的秒数。

#include <stdio.h>
#include <fcntl.h>
#include <time.h>
#include <unistd.h>
#include <string.h>


void read_loop(int fFile, double wWait)
{
    if (fFile < 0) return;

    double max_time = wWait, total_time = 0;
    struct timespec cycle_time = { 0, 50 * 1000 * 1000 };
    double add_time = (double) cycle_time.tv_sec + (double) cycle_time.tv_nsec / 1000000000.;

    char next_line[1024];

    FILE *input_file = fdopen(fFile, "r");

    while (total_time < max_time)
    {
    while (fgets(next_line, 1024, input_file))
     {
    write(STDOUT_FILENO, next_line, strlen(next_line));
    total_time = 0;
     }

    nanosleep(&cycle_time, NULL);
    total_time += add_time;
    }

    fclose(input_file);
}


int main(int argc, char *argv[])
{
    if (argc < 2)
    {
    fprintf(stderr, "%s [max time] (files...)\n", argv[0]);
    return 1;
    }

    int max_wait = strtoul(argv[1],0, 10);

    if (argc == 2)
    {
    fprintf(stderr, "%s: using standard input\n", argv[0]);
    fcntl(STDIN_FILENO, F_SETFL, O_NONBLOCK);
    read_loop(STDIN_FILENO, max_wait);
    return 0;
    }

    int current = 2;

    while (current < argc)
    {
    fprintf(stderr, "%s: switch to file '%s'\n", argv[0], argv[current]);
    int next_file = open(argv[current++], O_RDONLY | O_NONBLOCK);
    read_loop(next_file, max_wait);
    close(next_file);
    }

    return 0;
}

答案 1 :(得分:0)

您应该关闭FIFO的另一端。这应该向cat进程发送EOF。