9ef71efbe5d3bc33a9a3802b20529f5ffe0e4e6e
[m6w6/ext-http] / phpstr / phpstr.h
1
2 /* $Id$ */
3
4 #ifndef _PHPSTR_H_
5 #define _PHPSTR_H_
6
7 #include "php.h"
8
9 #ifdef PHP_WIN32
10 # define PHPSTR_API __declspec(dllexport)
11 #else
12 # define PHPSTR_API
13 #endif
14
15 #define PHPSTR(p) ((phpstr *) (p))
16 #define PHPSTR_VAL(p) (PHPSTR(p))->data
17 #define PHPSTR_LEN(p) (PHPSTR(p))->used
18
19 #define FREE_PHPSTR_PTR(STR) efree(STR)
20 #define FREE_PHPSTR_VAL(STR) phpstr_dtor(STR)
21 #define FREE_PHPSTR_ALL(STR) phpstr_free(STR)
22 #define FREE_PHPSTR(free, STR) \
23 switch (free) \
24 { \
25 case PHPSTR_FREE_PTR: efree(STR); break; \
26 case PHPSTR_FREE_VAL: phpstr_dtor(STR); break; \
27 case PHPSTR_FREE_ALL: phpstr_free(STR); break; \
28 case PHPSTR_FREE_NOT: break; \
29 default: break; \
30 }
31
32 #define RETURN_PHPSTR_PTR(STR) RETURN_PHPSTR((STR), PHPSTR_FREE_PTR, 0)
33 #define RETURN_PHPSTR_VAL(STR) RETURN_PHPSTR(&(STR), PHPSTR_FREE_NOT, 0)
34 #define RETVAL_PHPSTR_PTR(STR) RETVAL_PHPSTR((STR), PHPSTR_FREE_PTR, 0)
35 #define RETVAL_PHPSTR_VAL(STR) RETVAL_PHPSTR(&(STR), PHPSTR_FREE_NOT, 0)
36 /* RETURN_PHPSTR(buf, PHPSTR_FREE_PTR, 0) */
37 #define RETURN_PHPSTR(STR, free, dup) \
38 RETVAL_PHPSTR((STR), (free), (dup)); \
39 return;
40
41 #define RETVAL_PHPSTR(STR, free, dup) \
42 phpstr_fix(STR); \
43 RETVAL_STRINGL((STR)->data, (STR)->used, (dup)); \
44 FREE_PHPSTR((free), (STR));
45
46 typedef struct {
47 size_t size;
48 char *data;
49 size_t used;
50 size_t free;
51 } phpstr;
52
53 typedef enum {
54 PHPSTR_FREE_NOT = 0,
55 PHPSTR_FREE_PTR, /* efree() */
56 PHPSTR_FREE_VAL, /* phpstr_dtor() */
57 PHPSTR_FREE_ALL /* phpstr_free() */
58 } phpstr_free_t;
59
60 #define PHPSTR_ALL_FREE(STR) PHPSTR_FREE_ALL,(STR)
61 #define PHPSTR_PTR_FREE(STR) PHPSTR_FREE_PTR,(STR)
62 #define PHPSTR_VAL_FREE(STR) PHPSTR_FREE_VAL,(STR)
63 #define PHPSTR_NOT_FREE(STR) PHPSTR_FREE_NOT,(STR)
64
65 /* create a new phpstr */
66 #define phpstr_new() phpstr_init(NULL)
67 #define phpstr_init(b) phpstr_init_ex(b, 0, 0)
68 #define phpstr_clone(phpstr_pointer) phpstr_init_ex(NULL, (phpstr_pointer)->size, 0)
69 PHPSTR_API phpstr *phpstr_init_ex(phpstr *buf, size_t chunk_size, zend_bool pre_alloc);
70
71 /* create a phpstr from a zval or c-string */
72 #define phpstr_from_zval(z) phpstr_from_string(Z_STRVAL(z), Z_STRLEN(z))
73 #define phpstr_from_zval_ex(b, z) phpstr_from_string_ex(b, Z_STRVAL(z), Z_STRLEN(z))
74 #define phpstr_from_string(s, l) phpstr_from_string_ex(NULL, (s), (l))
75 PHPSTR_API phpstr *phpstr_from_string_ex(phpstr *buf, const char *string, size_t length);
76
77 /* usually only called from within the internal functions */
78 #define phpstr_resize(b, s) phpstr_resize_ex((b), (s), 0)
79 PHPSTR_API void phpstr_resize_ex(phpstr *buf, size_t len, size_t override_size);
80
81 /* append data to the phpstr */
82 #define phpstr_appends(b, a) phpstr_append((b), (a), sizeof(a)-1)
83 #define phpstr_appendl(b, a) phpstr_append((b), (a), strlen(a))
84 PHPSTR_API size_t phpstr_append(phpstr *buf, const char *append, size_t append_len);
85 PHPSTR_API size_t phpstr_appendf(phpstr *buf, const char *format, ...) PHP_ATTRIBUTE_FORMAT(printf, 2, 3);
86
87 /* insert data at a specific position of the phpstr */
88 #define phpstr_inserts(b, i, o) phpstr_insert((b), (i), sizeof(i)-1, (o))
89 #define phpstr_insertl(b, i, o) phpstr_insert((b), (i), strlen(i), (o))
90 PHPSTR_API size_t phpstr_insert(phpstr *buf, const char *insert, size_t insert_len, size_t offset);
91 PHPSTR_API size_t phpstr_insertf(phpstr *buf, size_t offset, const char *format, ...) PHP_ATTRIBUTE_FORMAT(printf, 3, 4);
92
93 /* prepend data */
94 #define phpstr_prepends(b, p) phpstr_prepend((b), (p), sizeof(p)-1)
95 #define phpstr_prependl(b, p) phpstr_prepend((b), (p), strlen(p))
96 PHPSTR_API size_t phpstr_prepend(phpstr *buf, const char *prepend, size_t prepend_len);
97 PHPSTR_API size_t phpstr_prependf(phpstr *buf, const char *format, ...) PHP_ATTRIBUTE_FORMAT(printf, 2, 3);
98
99 /* get a zero-terminated string */
100 PHPSTR_API char *phpstr_data(const phpstr *buf, char **into, size_t *len);
101
102 /* get a part of the phpstr */
103 #define phpstr_mid(b, o, l) phpstr_sub((b), (o), (l))
104 #define phpstr_left(b, l) phpstr_sub((b), 0, (l))
105 PHPSTR_API phpstr *phpstr_right(const phpstr *buf, size_t length);
106 PHPSTR_API phpstr *phpstr_sub(const phpstr *buf, size_t offset, size_t len);
107
108 /* remove a substring */
109 PHPSTR_API size_t phpstr_cut(phpstr *buf, size_t offset, size_t length);
110
111 /* get a complete phpstr duplicate */
112 PHPSTR_API phpstr *phpstr_dup(const phpstr *buf);
113
114 /* merge several phpstr objects
115 use like:
116
117 phpstr *final = phpstr_merge(3,
118 PHPSTR_NOT_FREE(&keep),
119 PHPSTR_ALL_FREE(middle_ptr),
120 PHPSTR_VAL_FREE(&local);
121 */
122 PHPSTR_API phpstr *phpstr_merge(unsigned argc, ...);
123 PHPSTR_API phpstr *phpstr_merge_ex(phpstr *buf, unsigned argc, ...);
124 PHPSTR_API phpstr *phpstr_merge_va(phpstr *buf, unsigned argc, va_list argv);
125
126 /* sets a trailing NUL byte */
127 PHPSTR_API void phpstr_fix(phpstr *buf);
128
129 /* free a phpstr objects contents */
130 PHPSTR_API void phpstr_dtor(phpstr *buf);
131
132 /* free a phpstr object completely */
133 PHPSTR_API void phpstr_free(phpstr *buf);
134
135 #endif
136
137
138 /*
139 * Local variables:
140 * tab-width: 4
141 * c-basic-offset: 4
142 * End:
143 * vim600: sw=4 ts=4 fdm=marker
144 * vim<600: sw=4 ts=4
145 */
146