version: minor cleanups

- remove typecasts and parentheses in zstd_version()
- create and use oldap_version() for OpenLDAP
- create and use psl_version() for libpsl
- reduce the size of the 40 byte buffers to 30 bytes
- use the brotil/zstd like the others (add the lib name in the functions)
- create and use idn_version for IDN builds
- handle (unlikely) error from ldap_get_option

Closes #15393
This commit is contained in:
Daniel Stenberg 2024-10-24 12:27:21 +02:00
parent ac7ae08f02
commit 9255e7a105
No known key found for this signature in database
GPG key ID: 5CC908FDB71E12C2

View file

@ -93,20 +93,71 @@ static void brotli_version(char *buf, size_t bufsz)
unsigned int major = brotli_version >> 24;
unsigned int minor = (brotli_version & 0x00FFFFFF) >> 12;
unsigned int patch = brotli_version & 0x00000FFF;
(void)msnprintf(buf, bufsz, "%u.%u.%u", major, minor, patch);
(void)msnprintf(buf, bufsz, "brotli/%u.%u.%u", major, minor, patch);
}
#endif
#ifdef HAVE_ZSTD
static void zstd_version(char *buf, size_t bufsz)
{
unsigned long zstd_version = (unsigned long)ZSTD_versionNumber();
unsigned int major = (unsigned int)(zstd_version / (100 * 100));
unsigned int minor = (unsigned int)((zstd_version -
(major * 100 * 100)) / 100);
unsigned int patch = (unsigned int)(zstd_version -
(major * 100 * 100) - (minor * 100));
(void)msnprintf(buf, bufsz, "%u.%u.%u", major, minor, patch);
unsigned int version = ZSTD_versionNumber();
unsigned int major = version / (100 * 100);
unsigned int minor = (version - (major * 100 * 100)) / 100;
unsigned int patch = version - (major * 100 * 100) - (minor * 100);
(void)msnprintf(buf, bufsz, "zstd/%u.%u.%u", major, minor, patch);
}
#endif
#ifdef USE_OPENLDAP
static void oldap_version(char *buf, size_t bufsz)
{
LDAPAPIInfo api;
api.ldapai_info_version = LDAP_API_INFO_VERSION;
if(ldap_get_option(NULL, LDAP_OPT_API_INFO, &api) == LDAP_OPT_SUCCESS) {
unsigned int patch = (unsigned int)(api.ldapai_vendor_version % 100);
unsigned int major = (unsigned int)(api.ldapai_vendor_version / 10000);
unsigned int minor =
(((unsigned int)api.ldapai_vendor_version - major * 10000)
- patch) / 100;
msnprintf(buf, bufsz, "%s/%u.%u.%u",
api.ldapai_vendor_name, major, minor, patch);
ldap_memfree(api.ldapai_vendor_name);
ber_memvfree((void **)api.ldapai_extensions);
}
else
msnprintf(buf, bufsz, "OpenLDAP");
}
#endif
#ifdef USE_LIBPSL
static void psl_version(char *buf, size_t bufsz)
{
#if defined(PSL_VERSION_MAJOR) && (PSL_VERSION_MAJOR > 0 || \
PSL_VERSION_MINOR >= 11)
int num = psl_check_version_number(0);
msnprintf(buf, bufsz, "libpsl/%d.%d.%d",
num >> 16, (num >> 8) & 0xff, num & 0xff);
#else
msnprintf(buf, bufsz, "libpsl/%s", psl_get_version());
#endif
}
#endif
#if defined(USE_LIBIDN2) || defined(USE_WIN32_IDN) || defined(USE_APPLE_IDN)
#define USE_IDN
#endif
#ifdef USE_IDN
static void idn_version(char *buf, size_t bufsz)
{
#ifdef USE_LIBIDN2
msnprintf(buf, bufsz, "libidn2/%s", idn2_check_version(NULL));
#elif defined(USE_WIN32_IDN)
msnprintf(buf, bufsz, "WinIDN");
#elif defined(USE_APPLE_IDN)
msnprintf(buf, bufsz, "AppleIDN");
#endif
}
#endif
@ -130,34 +181,34 @@ char *curl_version(void)
char ssl_version[200];
#endif
#ifdef HAVE_LIBZ
char z_version[40];
char z_version[30];
#endif
#ifdef HAVE_BROTLI
char br_version[40] = "brotli/";
char br_version[30];
#endif
#ifdef HAVE_ZSTD
char zst_version[40] = "zstd/";
char zstd_ver[30];
#endif
#ifdef USE_ARES
char cares_version[40];
char cares_version[30];
#endif
#if defined(USE_LIBIDN2)
char idn_version[40];
#ifdef USE_IDN
char idn_ver[30];
#endif
#ifdef USE_LIBPSL
char psl_version[40];
char psl_ver[30];
#endif
#ifdef USE_SSH
char ssh_version[40];
char ssh_version[30];
#endif
#ifdef USE_NGHTTP2
char h2_version[40];
char h2_version[30];
#endif
#ifdef USE_HTTP3
char h3_version[40];
char h3_version[30];
#endif
#ifdef USE_LIBRTMP
char rtmp_version[40];
char rtmp_version[30];
#endif
#ifdef USE_HYPER
char hyper_buf[30];
@ -190,43 +241,26 @@ char *curl_version(void)
src[i++] = z_version;
#endif
#ifdef HAVE_BROTLI
brotli_version(&br_version[7], sizeof(br_version) - 7);
brotli_version(br_version, sizeof(br_version));
src[i++] = br_version;
#endif
#ifdef HAVE_ZSTD
zstd_version(&zst_version[5], sizeof(zst_version) - 5);
src[i++] = zst_version;
zstd_version(zstd_ver, sizeof(zstd_ver));
src[i++] = zstd_ver;
#endif
#ifdef USE_ARES
msnprintf(cares_version, sizeof(cares_version),
"c-ares/%s", ares_version(NULL));
src[i++] = cares_version;
#endif
#ifdef USE_LIBIDN2
msnprintf(idn_version, sizeof(idn_version),
"libidn2/%s", idn2_check_version(NULL));
src[i++] = idn_version;
#elif defined(USE_WIN32_IDN)
src[i++] = (char *)"WinIDN";
#elif defined(USE_APPLE_IDN)
src[i++] = (char *)"AppleIDN";
#ifdef USE_IDN
idn_version(idn_ver, sizeof(idn_ver));
src[i++] = idn_ver;
#endif
#ifdef USE_LIBPSL
{
#if defined(PSL_VERSION_MAJOR) && (PSL_VERSION_MAJOR > 0 || \
PSL_VERSION_MINOR >= 11)
int num = psl_check_version_number(0);
msnprintf(psl_version, sizeof(psl_version), "libpsl/%d.%d.%d",
num >> 16, (num >> 8) & 0xff, num & 0xff);
#else
msnprintf(psl_version, sizeof(psl_version), "libpsl/%s",
psl_get_version());
psl_version(psl_ver, sizeof(psl_ver));
src[i++] = psl_ver;
#endif
src[i++] = psl_version;
}
#endif
#ifdef USE_SSH
Curl_ssh_version(ssh_version, sizeof(ssh_version));
src[i++] = ssh_version;
@ -253,23 +287,8 @@ char *curl_version(void)
src[i++] = gsasl_buf;
#endif
#ifdef USE_OPENLDAP
{
LDAPAPIInfo api;
api.ldapai_info_version = LDAP_API_INFO_VERSION;
if(ldap_get_option(NULL, LDAP_OPT_API_INFO, &api) == LDAP_OPT_SUCCESS) {
unsigned int patch = (unsigned int)(api.ldapai_vendor_version % 100);
unsigned int major = (unsigned int)(api.ldapai_vendor_version / 10000);
unsigned int minor =
(((unsigned int)api.ldapai_vendor_version - major * 10000)
- patch) / 100;
msnprintf(ldap_buf, sizeof(ldap_buf), "%s/%u.%u.%u",
api.ldapai_vendor_name, major, minor, patch);
src[i++] = ldap_buf;
ldap_memfree(api.ldapai_vendor_name);
ber_memvfree((void **)api.ldapai_extensions);
}
}
oldap_version(ldap_buf, sizeof(ldap_buf));
src[i++] = ldap_buf;
#endif
DEBUGASSERT(i <= VERSION_PARTS);