File: readln.h

package info (click to toggle)
sn 0.3.4a-2
  • links: PTS
  • area: main
  • in suites: woody
  • size: 784 kB
  • ctags: 826
  • sloc: ansic: 9,023; sh: 339; makefile: 208
file content (40 lines) | stat: -rw-r--r-- 1,166 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/*
 * This file is part of the sn package.
 * Distribution of sn is covered by the GNU GPL. See file COPYING.
 * Copyright  1998-2000 Harold Tay.
 * Copyright  2000- Patrik Rdman.
 */

#ifndef READLN_H
#define READLN_H

/*
 * Read a line from the given descriptor.  A line is considered as
 * terminated by the ch character.  Different ch terminators may
 * be used in different calls.  The length of the line is returned,
 * INCLUDING the terminator, but no null is appended.  The pointer
 * in *line refers to an internal data structure that will be
 * overwritten on the next call.  Data is not copied like fgets(3)!
 * readln_ready() must be called to initialize the structure.  tmo,
 * if > 0, is the timeout for reading, else no timeout.  readln()
 * will never return less than a complete line.  readln_done() frees
 * up the structure.
 */

struct readln {
   int fd;
   char *buf;
   char bf[104];
   int size;
   int used;
   int eaten;
   int tmo;
};

/* readln.c */

extern int readln_ready (int fd, int tmo, struct readln *rp);
extern void readln_done (struct readln *rp);
extern int readln (register struct readln *rp, char **line, int ch);

#endif