1 /*        $NetBSD: vstring_vstream.h,v 1.3 2020/03/18 19:05:22 christos Exp $   */
2 
3 #ifndef _VSTRING_VSTREAM_H_INCLUDED_
4 #define _VSTRING_VSTREAM_H_INCLUDED_
5 
6 /*++
7 /* NAME
8 /*        vstring_vstream 3h
9 /* SUMMARY
10 /*        auto-resizing string library
11 /* SYNOPSIS
12 /*        #include <vstring_vstream.h>
13 /* DESCRIPTION
14 
15  /*
16   * Utility library.
17   */
18 #include <vstream.h>
19 #include <vstring.h>
20 
21  /*
22   * External interface.
23   */
24 #define VSTRING_GET_FLAG_NONE (0)
25 #define VSTRING_GET_FLAG_APPEND         (1<<1)    /* append instead of overwrite */
26 
27 extern int WARN_UNUSED_RESULT vstring_get_flags(VSTRING *, VSTREAM *, int);
28 extern int WARN_UNUSED_RESULT vstring_get_flags_nonl(VSTRING *, VSTREAM *, int);
29 extern int WARN_UNUSED_RESULT vstring_get_flags_null(VSTRING *, VSTREAM *, int);
30 extern int WARN_UNUSED_RESULT vstring_get_flags_bound(VSTRING *, VSTREAM *, int, ssize_t);
31 extern int WARN_UNUSED_RESULT vstring_get_flags_nonl_bound(VSTRING *, VSTREAM *, int, ssize_t);
32 extern int WARN_UNUSED_RESULT vstring_get_flags_null_bound(VSTRING *, VSTREAM *, int, ssize_t);
33 
34  /*
35   * Convenience aliases for most use cases.
36   */
37 #define vstring_get(string, stream) \
38           vstring_get_flags((string), (stream), VSTRING_GET_FLAG_NONE)
39 #define vstring_get_nonl(string, stream) \
40           vstring_get_flags_nonl((string), (stream), VSTRING_GET_FLAG_NONE)
41 #define vstring_get_null(string, stream) \
42           vstring_get_flags_null((string), (stream), VSTRING_GET_FLAG_NONE)
43 
44 #define vstring_get_bound(string, stream, size) \
45           vstring_get_flags_bound((string), (stream), VSTRING_GET_FLAG_NONE, size)
46 #define vstring_get_nonl_bound(string, stream, size) \
47           vstring_get_flags_nonl_bound((string), (stream), \
48               VSTRING_GET_FLAG_NONE, size)
49 #define vstring_get_null_bound(string, stream, size) \
50           vstring_get_flags_null_bound((string), (stream), \
51               VSTRING_GET_FLAG_NONE, size)
52 
53  /*
54   * Backwards compatibility for code that still uses the vstring_fgets()
55   * interface. Unfortunately we can't change the macro name to upper case.
56   */
57 #define vstring_fgets(s, p) \
58           (vstring_get((s), (p)) == VSTREAM_EOF ? 0 : (s))
59 #define vstring_fgets_nonl(s, p) \
60           (vstring_get_nonl((s), (p)) == VSTREAM_EOF ? 0 : (s))
61 #define vstring_fgets_null(s, p) \
62           (vstring_get_null((s), (p)) == VSTREAM_EOF ? 0 : (s))
63 #define vstring_fgets_bound(s, p, l) \
64           (vstring_get_bound((s), (p), (l)) == VSTREAM_EOF ? 0 : (s))
65 #define vstring_fgets_nonl_bound(s, p, l) \
66           (vstring_get_nonl_bound((s), (p), (l)) == VSTREAM_EOF ? 0 : (s))
67 
68 /* LICENSE
69 /* .ad
70 /* .fi
71 /*        The Secure Mailer license must be distributed with this software.
72 /* AUTHOR(S)
73 /*        Wietse Venema
74 /*        IBM T.J. Watson Research
75 /*        P.O. Box 704
76 /*        Yorktown Heights, NY 10598, USA
77 /*
78 /*        Wietse Venema
79 /*        Google, Inc.
80 /*        111 8th Avenue
81 /*        New York, NY 10011, USA
82 /*--*/
83 
84 #endif
85