mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-11-28 14:21:00 +01:00
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 <string.h>
|
||||||
|
|
||||||
#include <haproxy/api.h>
|
#include <haproxy/api.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf.h>
|
||||||
#include <common/chunk.h>
|
#include <common/chunk.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
#include <common/istbuf.h>
|
#include <common/istbuf.h>
|
||||||
|
|||||||
@ -26,7 +26,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <haproxy/api.h>
|
#include <haproxy/api.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf-t.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
#include <common/memory.h>
|
#include <common/memory.h>
|
||||||
|
|
||||||
|
|||||||
@ -25,7 +25,7 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <haproxy/api.h>
|
#include <haproxy/api.h>
|
||||||
#include <common/standard.h>
|
#include <common/standard.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf-t.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
|
|
||||||
/* FCGI protocol version */
|
/* FCGI protocol version */
|
||||||
|
|||||||
@ -30,7 +30,7 @@
|
|||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <haproxy/api.h>
|
#include <haproxy/api.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf-t.h>
|
||||||
#include <common/http.h>
|
#include <common/http.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
|
|
||||||
|
|||||||
@ -23,7 +23,7 @@
|
|||||||
#ifndef _COMMON_HTTP_H
|
#ifndef _COMMON_HTTP_H
|
||||||
#define _COMMON_HTTP_H
|
#define _COMMON_HTTP_H
|
||||||
|
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf-t.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|||||||
@ -24,7 +24,7 @@
|
|||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <haproxy/api.h>
|
#include <haproxy/api.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
#include <common/http.h>
|
#include <common/http.h>
|
||||||
#include <common/http-hdr.h>
|
#include <common/http-hdr.h>
|
||||||
|
|||||||
@ -29,7 +29,7 @@
|
|||||||
#define _COMMON_ISTBUF_H
|
#define _COMMON_ISTBUF_H
|
||||||
|
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf.h>
|
||||||
#include <import/ist.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
|
* include/haproxy/buf.h
|
||||||
* Simple buffer handling.
|
* 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
|
* Permission is hereby granted, free of charge, to any person obtaining
|
||||||
* a copy of this software and associated documentation files (the
|
* a copy of this software and associated documentation files (the
|
||||||
@ -25,35 +25,13 @@
|
|||||||
* OTHER DEALINGS IN THE SOFTWARE.
|
* OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _COMMON_BUF_H
|
#ifndef _HAPROXY_BUF_H
|
||||||
#define _COMMON_BUF_H
|
#define _HAPROXY_BUF_H
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
|
||||||
#include <haproxy/api.h>
|
#include <haproxy/api.h>
|
||||||
|
#include <haproxy/buf-t.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 })
|
|
||||||
|
|
||||||
|
|
||||||
/***************************************************************************/
|
/***************************************************************************/
|
||||||
/* Functions used to compute offsets and pointers. Most of them exist in */
|
/* 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);
|
return br_head(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* _COMMON_BUF_H */
|
#endif /* _HAPROXY_BUF_H */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Local variables:
|
* Local variables:
|
||||||
@ -23,7 +23,7 @@
|
|||||||
#ifndef _PROTO_H1_HTX_H
|
#ifndef _PROTO_H1_HTX_H
|
||||||
#define _PROTO_H1_HTX_H
|
#define _PROTO_H1_HTX_H
|
||||||
|
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
#include <common/h1.h>
|
#include <common/h1.h>
|
||||||
|
|
||||||
|
|||||||
@ -23,7 +23,7 @@
|
|||||||
#ifndef _PROTO_HTTP_HTX_H
|
#ifndef _PROTO_HTTP_HTX_H
|
||||||
#define _PROTO_HTTP_HTX_H
|
#define _PROTO_HTTP_HTX_H
|
||||||
|
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
#include <common/regex.h>
|
#include <common/regex.h>
|
||||||
|
|
||||||
|
|||||||
@ -20,7 +20,7 @@
|
|||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
#include <common/mini-clist.h>
|
#include <common/mini-clist.h>
|
||||||
#include <common/regex.h>
|
#include <common/regex.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf-t.h>
|
||||||
|
|
||||||
#include <types/connection.h>
|
#include <types/connection.h>
|
||||||
#include <types/obj_type.h>
|
#include <types/obj_type.h>
|
||||||
|
|||||||
@ -25,7 +25,7 @@
|
|||||||
|
|
||||||
#include <import/ebistree.h>
|
#include <import/ebistree.h>
|
||||||
|
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf-t.h>
|
||||||
#include <common/http.h>
|
#include <common/http.h>
|
||||||
#include <common/htx.h>
|
#include <common/htx.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
|
|||||||
@ -23,7 +23,7 @@
|
|||||||
#define _TYPES_RING_H
|
#define _TYPES_RING_H
|
||||||
|
|
||||||
#include <haproxy/api-t.h>
|
#include <haproxy/api-t.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf-t.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
|
|
||||||
/* The code below handles circular buffers with single-producer and multiple
|
/* The code below handles circular buffers with single-producer and multiple
|
||||||
|
|||||||
@ -26,7 +26,7 @@
|
|||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
|
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf-t.h>
|
||||||
#include <common/http.h>
|
#include <common/http.h>
|
||||||
#include <common/mini-clist.h>
|
#include <common/mini-clist.h>
|
||||||
|
|
||||||
|
|||||||
@ -20,7 +20,7 @@
|
|||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
|
|
||||||
#include <haproxy/api.h>
|
#include <haproxy/api.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf.h>
|
||||||
#include <haproxy/debug.h>
|
#include <haproxy/debug.h>
|
||||||
#include <common/hathreads.h>
|
#include <common/hathreads.h>
|
||||||
#include <import/ist.h>
|
#include <import/ist.h>
|
||||||
|
|||||||
@ -25,7 +25,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <common/fcgi.h>
|
#include <common/fcgi.h>
|
||||||
|
#include <haproxy/buf.h>
|
||||||
|
|
||||||
/* Encodes header of a FCGI record into the chunk <out>. It returns non-zero on
|
/* 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
|
* success and 0 on failure (buffer full). <out> is a chunk, so the wrapping is
|
||||||
|
|||||||
@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <haproxy/api.h>
|
#include <haproxy/api.h>
|
||||||
#include <common/buf.h>
|
#include <haproxy/buf.h>
|
||||||
#include <common/hathreads.h>
|
#include <common/hathreads.h>
|
||||||
#include <types/applet.h>
|
#include <types/applet.h>
|
||||||
#include <proto/cli.h>
|
#include <proto/cli.h>
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user