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:
Willy Tarreau 2020-05-27 17:22:10 +02:00
parent 025beea507
commit 8dabda7497
18 changed files with 86 additions and 46 deletions

View File

@ -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>

View File

@ -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>

View File

@ -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 */

View File

@ -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>

View File

@ -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>
/*

View File

@ -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>

View File

@ -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
View 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:
*/

View File

@ -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:

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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

View File

@ -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>

View File

@ -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>

View File

@ -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

View File

@ -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>