REORG: include: split buf.h into haproxy/buf-t.h and haproxy/buf.h
File buf.h is one common cause of pain in the dependencies. Many files in the code need it to get the struct buffer definition, and a few also need the inlined functions to manipulate a buffer, but the file used to depend on a long chain only for BUG_ON() (addressed by last commit). Now buf.h is split into buf-t.h which only contains the type definitions, and buf.h for all inlined functions. Callers who don't care can continue to use buf.h but files in types/ must only use buf-t.h. sys/types.h had to be added to buf.h to get ssize_t as used by b_move(). It's worth noting that ssize_t is only supposed to be a size_t supporting -1, so b_move() ought to be rethought regarding this. The files were moved to haproxy/ and all their users were updated accordingly. A dependency issue was addressed on fcgi whose C file didn't include buf.h.
This commit is contained in:
parent
025beea507
commit
8dabda7497
@ -27,7 +27,7 @@
|
||||
#include <string.h>
|
||||
|
||||
#include <haproxy/api.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf.h>
|
||||
#include <common/chunk.h>
|
||||
#include <import/ist.h>
|
||||
#include <common/istbuf.h>
|
||||
|
@ -26,7 +26,7 @@
|
||||
#include <string.h>
|
||||
|
||||
#include <haproxy/api.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf-t.h>
|
||||
#include <import/ist.h>
|
||||
#include <common/memory.h>
|
||||
|
||||
|
@ -25,7 +25,7 @@
|
||||
#include <stdio.h>
|
||||
#include <haproxy/api.h>
|
||||
#include <common/standard.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf-t.h>
|
||||
#include <import/ist.h>
|
||||
|
||||
/* FCGI protocol version */
|
||||
|
@ -30,7 +30,7 @@
|
||||
|
||||
#include <string.h>
|
||||
#include <haproxy/api.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf-t.h>
|
||||
#include <common/http.h>
|
||||
#include <import/ist.h>
|
||||
|
||||
|
@ -23,7 +23,7 @@
|
||||
#ifndef _COMMON_HTTP_H
|
||||
#define _COMMON_HTTP_H
|
||||
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf-t.h>
|
||||
#include <import/ist.h>
|
||||
|
||||
/*
|
||||
|
@ -24,7 +24,7 @@
|
||||
|
||||
#include <stdio.h>
|
||||
#include <haproxy/api.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf.h>
|
||||
#include <import/ist.h>
|
||||
#include <common/http.h>
|
||||
#include <common/http-hdr.h>
|
||||
|
@ -29,7 +29,7 @@
|
||||
#define _COMMON_ISTBUF_H
|
||||
|
||||
#include <inttypes.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf.h>
|
||||
#include <import/ist.h>
|
||||
|
||||
|
||||
|
62
include/haproxy/buf-t.h
Normal file
62
include/haproxy/buf-t.h
Normal file
@ -0,0 +1,62 @@
|
||||
/*
|
||||
* include/haproxy/buf-t.h
|
||||
* Simple buffer handling - types definitions.
|
||||
*
|
||||
* Copyright (C) 2000-2020 Willy Tarreau - w@1wt.eu
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining
|
||||
* a copy of this software and associated documentation files (the
|
||||
* "Software"), to deal in the Software without restriction, including
|
||||
* without limitation the rights to use, copy, modify, merge, publish,
|
||||
* distribute, sublicense, and/or sell copies of the Software, and to
|
||||
* permit persons to whom the Software is furnished to do so, subject to
|
||||
* the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be
|
||||
* included in all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
||||
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#ifndef _HAPROXY_BUF_T_H
|
||||
#define _HAPROXY_BUF_T_H
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
/* Structure defining a buffer's head */
|
||||
struct buffer {
|
||||
size_t size; /* buffer size in bytes */
|
||||
char *area; /* points to <size> bytes */
|
||||
size_t data; /* amount of data after head including wrapping */
|
||||
size_t head; /* start offset of remaining data relative to area */
|
||||
};
|
||||
|
||||
/* A buffer may be in 3 different states :
|
||||
* - unallocated : size == 0, area == 0 (b_is_null() is true)
|
||||
* - waiting : size == 0, area != 0 (b_is_null() is true)
|
||||
* - allocated : size > 0, area > 0 (b_is_null() is false)
|
||||
*/
|
||||
|
||||
/* initializers for certain buffer states. It is important that the NULL buffer
|
||||
* remains the one with all fields initialized to zero so that a calloc() or a
|
||||
* memset() on a struct automatically sets a NULL buffer.
|
||||
*/
|
||||
#define BUF_NULL ((struct buffer){ })
|
||||
#define BUF_WANTED ((struct buffer){ .area = (char *)1 })
|
||||
#define BUF_RING ((struct buffer){ .area = (char *)2 })
|
||||
|
||||
#endif /* _HAPROXY_BUF_T_H */
|
||||
|
||||
/*
|
||||
* Local variables:
|
||||
* c-indent-level: 8
|
||||
* c-basic-offset: 8
|
||||
* End:
|
||||
*/
|
@ -1,8 +1,8 @@
|
||||
/*
|
||||
* include/common/buf.h
|
||||
* Simple buffer handling.
|
||||
* include/haproxy/buf.h
|
||||
* Simple buffer handling - functions definitions.
|
||||
*
|
||||
* Copyright (C) 2000-2018 Willy Tarreau - w@1wt.eu
|
||||
* Copyright (C) 2000-2020 Willy Tarreau - w@1wt.eu
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining
|
||||
* a copy of this software and associated documentation files (the
|
||||
@ -25,35 +25,13 @@
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#ifndef _COMMON_BUF_H
|
||||
#define _COMMON_BUF_H
|
||||
#ifndef _HAPROXY_BUF_H
|
||||
#define _HAPROXY_BUF_H
|
||||
|
||||
#include <sys/types.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
#include <haproxy/api.h>
|
||||
|
||||
/* Structure defining a buffer's head */
|
||||
struct buffer {
|
||||
size_t size; /* buffer size in bytes */
|
||||
char *area; /* points to <size> bytes */
|
||||
size_t data; /* amount of data after head including wrapping */
|
||||
size_t head; /* start offset of remaining data relative to area */
|
||||
};
|
||||
|
||||
/* A buffer may be in 3 different states :
|
||||
* - unallocated : size == 0, area == 0 (b_is_null() is true)
|
||||
* - waiting : size == 0, area != 0 (b_is_null() is true)
|
||||
* - allocated : size > 0, area > 0 (b_is_null() is false)
|
||||
*/
|
||||
|
||||
/* initializers for certain buffer states. It is important that the NULL buffer
|
||||
* remains the one with all fields initialized to zero so that a calloc() or a
|
||||
* memset() on a struct automatically sets a NULL buffer.
|
||||
*/
|
||||
#define BUF_NULL ((struct buffer){ })
|
||||
#define BUF_WANTED ((struct buffer){ .area = (char *)1 })
|
||||
#define BUF_RING ((struct buffer){ .area = (char *)2 })
|
||||
|
||||
#include <haproxy/buf-t.h>
|
||||
|
||||
/***************************************************************************/
|
||||
/* Functions used to compute offsets and pointers. Most of them exist in */
|
||||
@ -1034,7 +1012,7 @@ static inline struct buffer *br_del_head(struct buffer *r)
|
||||
return br_head(r);
|
||||
}
|
||||
|
||||
#endif /* _COMMON_BUF_H */
|
||||
#endif /* _HAPROXY_BUF_H */
|
||||
|
||||
/*
|
||||
* Local variables:
|
@ -23,7 +23,7 @@
|
||||
#ifndef _PROTO_H1_HTX_H
|
||||
#define _PROTO_H1_HTX_H
|
||||
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf.h>
|
||||
#include <import/ist.h>
|
||||
#include <common/h1.h>
|
||||
|
||||
|
@ -23,7 +23,7 @@
|
||||
#ifndef _PROTO_HTTP_HTX_H
|
||||
#define _PROTO_HTTP_HTX_H
|
||||
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf.h>
|
||||
#include <import/ist.h>
|
||||
#include <common/regex.h>
|
||||
|
||||
|
@ -20,7 +20,7 @@
|
||||
#include <import/ist.h>
|
||||
#include <common/mini-clist.h>
|
||||
#include <common/regex.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf-t.h>
|
||||
|
||||
#include <types/connection.h>
|
||||
#include <types/obj_type.h>
|
||||
|
@ -25,7 +25,7 @@
|
||||
|
||||
#include <import/ebistree.h>
|
||||
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf-t.h>
|
||||
#include <common/http.h>
|
||||
#include <common/htx.h>
|
||||
#include <import/ist.h>
|
||||
|
@ -23,7 +23,7 @@
|
||||
#define _TYPES_RING_H
|
||||
|
||||
#include <haproxy/api-t.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf-t.h>
|
||||
#include <import/ist.h>
|
||||
|
||||
/* The code below handles circular buffers with single-producer and multiple
|
||||
|
@ -26,7 +26,7 @@
|
||||
#include <sys/socket.h>
|
||||
#include <netinet/in.h>
|
||||
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf-t.h>
|
||||
#include <common/http.h>
|
||||
#include <common/mini-clist.h>
|
||||
|
||||
|
@ -20,7 +20,7 @@
|
||||
#include <sys/wait.h>
|
||||
|
||||
#include <haproxy/api.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf.h>
|
||||
#include <haproxy/debug.h>
|
||||
#include <common/hathreads.h>
|
||||
#include <import/ist.h>
|
||||
|
@ -25,7 +25,7 @@
|
||||
*/
|
||||
|
||||
#include <common/fcgi.h>
|
||||
|
||||
#include <haproxy/buf.h>
|
||||
|
||||
/* Encodes header of a FCGI record into the chunk <out>. It returns non-zero on
|
||||
* success and 0 on failure (buffer full). <out> is a chunk, so the wrapping is
|
||||
|
@ -20,7 +20,7 @@
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <haproxy/api.h>
|
||||
#include <common/buf.h>
|
||||
#include <haproxy/buf.h>
|
||||
#include <common/hathreads.h>
|
||||
#include <types/applet.h>
|
||||
#include <proto/cli.h>
|
||||
|
Loading…
x
Reference in New Issue
Block a user