mirror of
https://github.com/openssl/openssl.git
synced 2025-01-18 13:44:20 +08:00
c626fda8a6
Check returns of sk_POLICY_MAPPING_push, sk_GENERAL_NAME_push, sk_ACCESS_DESCRIPTION_push, sk_X509_push, sk_X509_NAME_push, sk_OPENSSL_CSTRING_push, sk_SCT_push, sk_DIST_POINT_push, sk_OSSL_CMP_CRLSTATUS_push, sk_ASN1_UTF8STRING_push and sk_ASN1_OBJECT_push and handle appropriately. Reviewed-by: Saša Nedvědický <sashan@openssl.org> Reviewed-by: Tomas Mraz <tomas@openssl.org> (Merged from https://github.com/openssl/openssl/pull/26240)
47 lines
1.2 KiB
C
47 lines
1.2 KiB
C
/*
|
|
* Copyright 2019-2022 The OpenSSL Project Authors. All Rights Reserved.
|
|
*
|
|
* Licensed under the Apache License 2.0 (the "License"). You may not use
|
|
* this file except in compliance with the License. You can obtain a copy
|
|
* in the file LICENSE in the source distribution or at
|
|
* https://www.openssl.org/source/license.html
|
|
*/
|
|
|
|
#include <string.h>
|
|
#include <openssl/bio.h>
|
|
#include <openssl/safestack.h>
|
|
#include "names.h"
|
|
#include "internal/e_os.h"
|
|
|
|
int name_cmp(const char * const *a, const char * const *b)
|
|
{
|
|
return OPENSSL_strcasecmp(*a, *b);
|
|
}
|
|
|
|
void collect_names(const char *name, void *vdata)
|
|
{
|
|
STACK_OF(OPENSSL_CSTRING) *names = vdata;
|
|
|
|
/* A failure to push cannot be handled so we ignore the result. */
|
|
(void)sk_OPENSSL_CSTRING_push(names, name);
|
|
}
|
|
|
|
void print_names(BIO *out, STACK_OF(OPENSSL_CSTRING) *names)
|
|
{
|
|
int i = sk_OPENSSL_CSTRING_num(names);
|
|
int j;
|
|
|
|
sk_OPENSSL_CSTRING_sort(names);
|
|
if (i > 1)
|
|
BIO_printf(out, "{ ");
|
|
for (j = 0; j < i; j++) {
|
|
const char *name = sk_OPENSSL_CSTRING_value(names, j);
|
|
|
|
if (j > 0)
|
|
BIO_printf(out, ", ");
|
|
BIO_printf(out, "%s", name);
|
|
}
|
|
if (i > 1)
|
|
BIO_printf(out, " }");
|
|
}
|