mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-08-07 07:37:02 +02:00
MINOR: startup: allow hap_register_feature() to enable a feature in the list
This patch allows hap_register_feature() to enable a feature in the list which was already registered and marked disabled. This way we could enable automatically some features under certain condition without the need of the USE argument with make and correctly report its activation.
This commit is contained in:
parent
7034f2ca48
commit
2fe4cbd8e5
@ -347,13 +347,30 @@ void hap_register_feature(const char *name)
|
||||
static int must_free = 0;
|
||||
int new_len = strlen(build_features) + 2 + strlen(name);
|
||||
char *new_features;
|
||||
char *found, *endp;
|
||||
|
||||
new_features = malloc(new_len + 1);
|
||||
if (!new_features)
|
||||
return;
|
||||
|
||||
strlcpy2(new_features, build_features, new_len);
|
||||
snprintf(new_features, new_len + 1, "%s +%s", build_features, name);
|
||||
|
||||
/* look if the string already exists */
|
||||
/* must be a complete feature name with a space of end of string behind (eg OPENSSL vs OPENSSL_AWSLC) */
|
||||
found = strstr(new_features, name);
|
||||
endp = found+strlen(name);
|
||||
|
||||
if (found && (*endp == ' ' || *endp == '\0')) {
|
||||
|
||||
/* if the feature name was found with a '-' replace it by a '+' */
|
||||
if ((found-1 >= new_features) && (*(found-1) == '-')) {
|
||||
*(found-1) = '+';
|
||||
}
|
||||
|
||||
} else {
|
||||
/* if we didn't find the feature add it to the string */
|
||||
snprintf(new_features, new_len + 1, "%s +%s", build_features, name);
|
||||
}
|
||||
|
||||
if (must_free)
|
||||
ha_free(&build_features);
|
||||
|
Loading…
Reference in New Issue
Block a user