📄 zread.c
字号:
/* zread - read data from file descriptor into buffer with retries *//* Copyright (C) 1999-2002 Free Software Foundation, Inc. This file is part of GNU Bash, the Bourne Again SHell. Bash is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Bash is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Bash. If not, see <http://www.gnu.org/licenses/>.*/#include <config.h>#include <sys/types.h>#if defined (HAVE_UNISTD_H)# include <unistd.h>#endif#include <errno.h>#if !defined (errno)extern int errno;#endif#ifndef SEEK_CUR# define SEEK_CUR 1#endif/* Read LEN bytes from FD into BUF. Retry the read on EINTR. Any other error causes the loop to break. */ssize_tzread (fd, buf, len) int fd; char *buf; size_t len;{ ssize_t r; while ((r = read (fd, buf, len)) < 0 && errno == EINTR) ; return r;}/* Read LEN bytes from FD into BUF. Retry the read on EINTR, up to three interrupts. Any other error causes the loop to break. */#ifdef NUM_INTR# undef NUM_INTR#endif#define NUM_INTR 3ssize_tzreadretry (fd, buf, len) int fd; char *buf; size_t len;{ ssize_t r; int nintr; for (nintr = 0; ; ) { r = read (fd, buf, len); if (r >= 0) return r; if (r == -1 && errno == EINTR) { if (++nintr >= NUM_INTR) return -1; continue; } return r; }}/* Call read(2) and allow it to be interrupted. Just a stub for now. */ssize_tzreadintr (fd, buf, len) int fd; char *buf; size_t len;{ return (read (fd, buf, len));}/* Read one character from FD and return it in CP. Return values are as in read(2). This does some local buffering to avoid many one-character calls to read(2), like those the `read' builtin performs. */static char lbuf[128];static size_t lind, lused;ssize_tzreadc (fd, cp) int fd; char *cp;{ ssize_t nr; if (lind == lused || lused == 0) { nr = zread (fd, lbuf, sizeof (lbuf)); lind = 0; if (nr <= 0) { lused = 0; return nr; } lused = nr; } if (cp) *cp = lbuf[lind++]; return 1;}/* Don't mix calls to zreadc and zreadcintr in the same function, since they use the same local buffer. */ssize_tzreadcintr (fd, cp) int fd; char *cp;{ ssize_t nr; if (lind == lused || lused == 0) { nr = zreadintr (fd, lbuf, sizeof (lbuf)); lind = 0; if (nr <= 0) { lused = 0; return nr; } lused = nr; } if (cp) *cp = lbuf[lind++]; return 1;}voidzreset (){ lind = lused = 0;}/* Sync the seek pointer for FD so that the kernel's idea of the last char read is the last char returned by zreadc. */voidzsyncfd (fd) int fd;{ off_t off; int r; off = lused - lind; r = 0; if (off > 0) r = lseek (fd, -off, SEEK_CUR); if (r >= 0) lused = lind = 0;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -