blob: a53d29375049d3c77580e9e7e034642dbe1cc753 [file] [log] [blame]
Willy Tarreau2ac57182012-04-19 15:24:50 +02001/*
2 * include/types/arg.h
3 * This file contains structure declarations for generaic argument parsing.
4 *
5 * Copyright 2012 Willy Tarreau <w@1wt.eu>
6 *
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 _TYPES_ARG_H
23#define _TYPES_ARG_H
24
25#include <sys/socket.h>
26#include <netinet/in.h>
Willy Tarreauc7e42382012-08-24 19:22:53 +020027
28#include <common/chunk.h>
Willy Tarreaua4312fa2013-04-02 16:34:32 +020029#include <common/mini-clist.h>
Willy Tarreau2ac57182012-04-19 15:24:50 +020030
31enum {
32 ARGT_STOP = 0, /* end of the arg list */
33 ARGT_UINT, /* unsigned integer, which is a positive integer without any sign */
34 ARGT_SINT, /* signed integer, the sign (+/-) was explicit. Falls back to UINT if no sign. */
35 ARGT_STR, /* string */
36 ARGT_IPV4, /* an IPv4 address */
37 ARGT_MSK4, /* an IPv4 address mask (integer or dotted), stored as ARGT_IPV4 */
38 ARGT_IPV6, /* an IPv6 address */
39 ARGT_MSK6, /* an IPv6 address mask (integer or dotted), stored as ARGT_IPV4 */
40 ARGT_TIME, /* a delay in ms by default, stored as ARGT_UINT */
41 ARGT_SIZE, /* a size in bytes by default, stored as ARGT_UINT */
42 ARGT_FE, /* a pointer to a frontend only */
43 ARGT_BE, /* a pointer to a backend only */
44 ARGT_TAB, /* a pointer to a stick table */
45 ARGT_SRV, /* a pointer to a server */
46 ARGT_USR, /* a pointer to a user list */
47 ARGT_UNASSIGNED15, /* will probably be used for variables later */
48 ARGT_NBTYPES /* no more values past 15 */
49};
50
Willy Tarreaua4312fa2013-04-02 16:34:32 +020051/* context where arguments are used, in order to help error reporting */
52enum {
53 ARGC_ACL = 0, /* ACL */
54 ARGC_STK, /* sticking rule */
55 ARGC_TRK, /* tracking rule */
56 ARGC_LOG, /* log-format */
57 ARGC_HDR, /* add-header */
58 ARGC_UIF, /* unique-id-format */
59};
60
Willy Tarreau2ac57182012-04-19 15:24:50 +020061/* some types that are externally defined */
62struct proxy;
63struct server;
64struct userlist;
65
66union arg_data {
67 unsigned int uint; /* used for uint, time, size */
68 int sint;
69 struct chunk str;
70 struct in_addr ipv4;
71 struct in6_addr ipv6;
72 struct proxy *prx; /* used for fe, be, tables */
73 struct server *srv;
74 struct userlist *usr;
75};
76
77struct arg {
Willy Tarreau496aa012012-06-01 10:38:29 +020078 unsigned char type; /* argument type, ARGT_* */
79 unsigned char unresolved; /* argument contains a string in <str> that must be resolved and freed */
80 union arg_data data; /* argument data */
Willy Tarreau2ac57182012-04-19 15:24:50 +020081};
82
Willy Tarreaua4312fa2013-04-02 16:34:32 +020083/* arg lists are used to store information about arguments that could not be
84 * resolved when parsing the configuration. The head is an arg_list which
85 * serves as a template to create new entries. Nothing here is allocated,
86 * so plain copies are OK.
87 */
88struct arg_list {
89 struct list list; /* chaining with other arg_list, or list head */
90 struct arg *arg; /* pointer to the arg, NULL on list head */
91 int arg_pos; /* argument position */
92 int ctx; /* context where the arg is used (ARGC_*) */
93 const char *kw; /* keyword making use of these args */
94 const char *conv; /* conv keyword when in conv, otherwise NULL */
95 const char *file; /* file name where the args are referenced */
96 int line; /* line number where the args are referenced */
97};
Willy Tarreau2ac57182012-04-19 15:24:50 +020098
99#endif /* _TYPES_ARG_H */
100
101/*
102 * Local variables:
103 * c-indent-level: 8
104 * c-basic-offset: 8
105 * End:
106 */