blob: 95d63a53acc07cebee94a7950306585f114dc38f [file] [log] [blame]
Willy Tarreaubaaee002006-06-26 02:48:02 +02001/*
2 include/proto/buffers.h
3 Buffer management definitions, macros and inline functions.
4
Willy Tarreaue09e0ce2007-03-18 16:31:29 +01005 Copyright (C) 2000-2007 Willy Tarreau - w@1wt.eu
Willy Tarreaubaaee002006-06-26 02:48:02 +02006
7 This library is free software; you can redistribute it and/or
8 modify it under the terms of the GNU Lesser General Public
9 License as published by the Free Software Foundation, version 2.1
10 exclusively.
11
12 This library is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 Lesser General Public License for more details.
16
17 You should have received a copy of the GNU Lesser General Public
18 License along with this library; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20*/
21
22#ifndef _PROTO_BUFFERS_H
23#define _PROTO_BUFFERS_H
24
Willy Tarreau7341d942007-05-13 19:56:02 +020025#include <stdio.h>
Willy Tarreau0f772532006-12-23 20:51:41 +010026#include <stdlib.h>
Willy Tarreau7341d942007-05-13 19:56:02 +020027#include <string.h>
Willy Tarreau0f772532006-12-23 20:51:41 +010028
Willy Tarreaue3ba5f02006-06-29 18:54:54 +020029#include <common/config.h>
Willy Tarreau7341d942007-05-13 19:56:02 +020030#include <common/memory.h>
Willy Tarreaufa645582007-06-03 15:59:52 +020031#include <common/time.h>
32
Willy Tarreaubaaee002006-06-26 02:48:02 +020033#include <types/buffers.h>
34
Willy Tarreau7341d942007-05-13 19:56:02 +020035extern struct pool_head *pool2_buffer;
36
37/* perform minimal intializations, report 0 in case of error, 1 if OK. */
38int init_buffer();
39
Willy Tarreau54469402006-07-29 16:59:06 +020040/* Initializes all fields in the buffer. The ->rlim field is initialized last
41 * so that the compiler can optimize it away if changed immediately after the
42 * call to this function.
43 */
44static inline void buffer_init(struct buffer *buf)
45{
46 buf->l = buf->total = buf->flags = 0;
Willy Tarreaue09e0ce2007-03-18 16:31:29 +010047 buf->rlim = buf->r = buf->lr = buf->w = buf->data;
Willy Tarreau54469402006-07-29 16:59:06 +020048}
49
Willy Tarreaubaaee002006-06-26 02:48:02 +020050/* returns 1 if the buffer is empty, 0 otherwise */
Willy Tarreaub17916e2006-10-15 15:17:57 +020051static inline int buffer_isempty(const struct buffer *buf)
Willy Tarreaubaaee002006-06-26 02:48:02 +020052{
53 return buf->l == 0;
54}
55
56/* returns 1 if the buffer is full, 0 otherwise */
Willy Tarreaub17916e2006-10-15 15:17:57 +020057static inline int buffer_isfull(const struct buffer *buf) {
Willy Tarreaubaaee002006-06-26 02:48:02 +020058 return buf->l == BUFSIZE;
59}
60
61/* flushes any content from buffer <buf> */
62static inline void buffer_flush(struct buffer *buf)
63{
Willy Tarreaue09e0ce2007-03-18 16:31:29 +010064 buf->r = buf->lr = buf->w = buf->data;
Willy Tarreaubaaee002006-06-26 02:48:02 +020065 buf->l = 0;
66}
67
Willy Tarreaufa645582007-06-03 15:59:52 +020068/* marks the buffer as "shutdown pending" for reads and cancels the timeout */
69static inline void buffer_shutr(struct buffer *buf)
70{
71 tv_eternity(&buf->rex);
72 buf->flags |= BF_SHUTR_PENDING;
73}
74
75/* marks the buffer as "shutdown pending" for writes and cancels the timeout */
76static inline void buffer_shutw(struct buffer *buf)
77{
78 tv_eternity(&buf->wex);
79 buf->flags |= BF_SHUTW_PENDING;
80}
81
Willy Tarreaubaaee002006-06-26 02:48:02 +020082
83/* returns the maximum number of bytes writable at once in this buffer */
Willy Tarreaub17916e2006-10-15 15:17:57 +020084static inline int buffer_max(const struct buffer *buf)
Willy Tarreaubaaee002006-06-26 02:48:02 +020085{
86 if (buf->l == BUFSIZE)
87 return 0;
88 else if (buf->r >= buf->w)
89 return buf->data + BUFSIZE - buf->r;
90 else
91 return buf->w - buf->r;
92}
93
94
95/*
96 * Tries to realign the given buffer, and returns how many bytes can be written
97 * there at once without overwriting anything.
98 */
99static inline int buffer_realign(struct buffer *buf)
100{
101 if (buf->l == 0) {
102 /* let's realign the buffer to optimize I/O */
Willy Tarreaue09e0ce2007-03-18 16:31:29 +0100103 buf->r = buf->w = buf->lr = buf->data;
Willy Tarreaubaaee002006-06-26 02:48:02 +0200104 }
105 return buffer_max(buf);
106}
107
108
109int buffer_write(struct buffer *buf, const char *msg, int len);
Willy Tarreauc0dde7a2007-01-01 21:38:07 +0100110int buffer_write_chunk(struct buffer *buf, struct chunk *chunk);
Willy Tarreau4af6f3a2007-03-18 22:36:26 +0100111int buffer_replace(struct buffer *b, char *pos, char *end, const char *str);
112int buffer_replace2(struct buffer *b, char *pos, char *end, const char *str, int len);
113int buffer_insert_line2(struct buffer *b, char *pos, const char *str, int len);
Willy Tarreauc0dde7a2007-01-01 21:38:07 +0100114int chunk_printf(struct chunk *chk, int size, const char *fmt, ...);
Willy Tarreau8d5d7f22007-01-21 19:16:41 +0100115void buffer_dump(FILE *o, struct buffer *b, int from, int to);
Willy Tarreaubaaee002006-06-26 02:48:02 +0200116
Willy Tarreau0f772532006-12-23 20:51:41 +0100117/*
118 * frees the destination chunk if already allocated, allocates a new string,
119 * and copies the source into it. The pointer to the destination string is
120 * returned, or NULL if the allocation fails or if any pointer is NULL..
121 */
122static inline char *chunk_dup(struct chunk *dst, const struct chunk *src) {
123 if (!dst || !src || !src->str)
124 return NULL;
125 if (dst->str)
126 free(dst->str);
127 dst->len = src->len;
128 dst->str = (char *)malloc(dst->len);
129 memcpy(dst->str, src->str, dst->len);
130 return dst->str;
131}
Willy Tarreaubaaee002006-06-26 02:48:02 +0200132
133#endif /* _PROTO_BUFFERS_H */
134
135/*
136 * Local variables:
137 * c-indent-level: 8
138 * c-basic-offset: 8
139 * End:
140 */