summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/ui/ui_util.c
diff options
context:
space:
mode:
authortb <>2024-01-13 11:08:39 +0000
committertb <>2024-01-13 11:08:39 +0000
commitce175ea71c55a0f97153dd4dc707826abc1242e7 (patch)
treef1a62b5297113e91a818c32f3ecb135d9a98c389 /src/lib/libcrypto/ui/ui_util.c
parentd7ceb399503967145b817054eeaf0251de1eb565 (diff)
downloadopenbsd-ce175ea71c55a0f97153dd4dc707826abc1242e7.tar.gz
openbsd-ce175ea71c55a0f97153dd4dc707826abc1242e7.tar.bz2
openbsd-ce175ea71c55a0f97153dd4dc707826abc1242e7.zip
Reimplement {EVP_CIPHER,EVP_MD,OBJ_NAME}_do_all{,_sorted}(3)
This implements the do_all API by simple loops over the tables of digests and ciphers. Since some ciphers are only available on some platforms, we need to skip them if necessary. We use loops in each of the functions rather the convoluted way of reducing some of the loops to others. Since the tables are sorted, as ensured by regress, both do_all() and do_all_sorted() walk the lists in order. In particular, we no longer need to allocate to be able to sort hash tables by name on the fly in a void function that may end up doing nothing because allocation failed. We still need to do an unchecked OPENSSL_init_crypto() call. But that's what prayer and clean living are there for (as beck put it). The OBJ_NAME API is completely misnamed. It has little to do with objects and a lot to do with EVP. Therefore we implement what will remain from its saner replacement in the evp directory, i.e., evp_names.c. ok jsing
Diffstat (limited to 'src/lib/libcrypto/ui/ui_util.c')
0 files changed, 0 insertions, 0 deletions