MINOR: proxy: Add a "server by name" tree to proxy.
Add a tree to proxy struct to lookup by name for servers attached
to this proxy and populated it at parsing time.
diff --git a/include/types/proxy.h b/include/types/proxy.h
index 45ef2c8..ca24dbf 100644
--- a/include/types/proxy.h
+++ b/include/types/proxy.h
@@ -447,6 +447,7 @@
int line; /* line where the section appears */
struct eb_root used_listener_id;/* list of listener IDs in use */
struct eb_root used_server_id; /* list of server IDs in use */
+ struct eb_root used_server_name; /* list of server names in use */
struct list bind; /* list of bind settings */
struct list listeners; /* list of listeners belonging to this frontend */
struct arg_list args; /* sample arg list that need to be resolved */
diff --git a/include/types/server.h b/include/types/server.h
index 219f5ab..574d40e 100644
--- a/include/types/server.h
+++ b/include/types/server.h
@@ -320,6 +320,7 @@
struct {
const char *file; /* file where the section appears */
struct eb32_node id; /* place in the tree of used IDs */
+ struct ebpt_node name; /* place in the tree of used names */
int line; /* line where the section appears */
} conf; /* config information */
/* Template information used only for server objects which
diff --git a/src/cfgparse.c b/src/cfgparse.c
index 5b59413..bec5b01 100644
--- a/src/cfgparse.c
+++ b/src/cfgparse.c
@@ -3143,6 +3143,8 @@
next_id = get_next_id(&curproxy->conf.used_server_id, next_id);
newsrv->conf.id.key = newsrv->puid = next_id;
eb32_insert(&curproxy->conf.used_server_id, &newsrv->conf.id);
+ newsrv->conf.name.key = newsrv->id;
+ ebis_insert(&curproxy->conf.used_server_name, &newsrv->conf.name);
}
next_id++;
newsrv = newsrv->next;