From 3c833a5a8bc9a8e7e3583277c72b5e81f1e0c7ba Mon Sep 17 00:00:00 2001 From: Ken Raeburn Date: Sat, 7 Oct 2006 07:51:48 +0000 Subject: [PATCH] Initialize accessor fields at compile time, under C99 and GCC git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@18667 dc483132-0cff-0310-8789-dd5450dbe970 --- src/lib/krb5/os/accessor.c | 79 +++++++++++++++++++++++--------------- 1 file changed, 49 insertions(+), 30 deletions(-) diff --git a/src/lib/krb5/os/accessor.c b/src/lib/krb5/os/accessor.c index 12038ac99..cd7d0c37f 100644 --- a/src/lib/krb5/os/accessor.c +++ b/src/lib/krb5/os/accessor.c @@ -28,43 +28,62 @@ #include "k5-int.h" #include "os-proto.h" +/* If this trick gets used elsewhere, move it to k5-platform.h. */ +#ifndef DESIGNATED_INITIALIZERS +#define DESIGNATED_INITIALIZERS \ + /* ANSI/ISO C 1999 supports this... */ \ + (__STDC_VERSION__ >= 199901L \ + /* ...as does GCC, since version 2.something. */ \ + || (!defined __cplusplus && __GNUC__ >= 3)) +#endif + krb5_error_code KRB5_CALLCONV krb5int_accessor(krb5int_access *internals, krb5_int32 version) { - if (version == KRB5INT_ACCESS_VERSION) - { - krb5int_access internals_temp; - internals_temp.free_addrlist = krb5int_free_addrlist; - internals_temp.krb5_hmac = krb5_hmac; - internals_temp.md5_hash_provider = &krb5int_hash_md5; - internals_temp.arcfour_enc_provider = &krb5int_enc_arcfour; - internals_temp.sendto_udp = &krb5int_sendto; - internals_temp.add_host_to_list = krb5int_add_host_to_list; + if (version == KRB5INT_ACCESS_VERSION) { +#if DESIGNATED_INITIALIZERS +#define S(FIELD, VAL) .FIELD = VAL + static const krb5int_access internals_temp = { +#else +#define S(FIELD, VAL) internals_temp.FIELD = VAL + krb5int_access internals_temp; +#endif + S (free_addrlist, krb5int_free_addrlist), + S (krb5_hmac, krb5_hmac), + S (md5_hash_provider, &krb5int_hash_md5), + S (arcfour_enc_provider, &krb5int_enc_arcfour), + S (sendto_udp, &krb5int_sendto), + S (add_host_to_list, krb5int_add_host_to_list), #ifdef KRB5_DNS_LOOKUP - internals_temp.make_srv_query_realm = krb5int_make_srv_query_realm; - internals_temp.free_srv_dns_data = krb5int_free_srv_dns_data; - internals_temp.use_dns_kdc = _krb5_use_dns_kdc; + S (make_srv_query_realm, krb5int_make_srv_query_realm), + S (free_srv_dns_data, krb5int_free_srv_dns_data), + S (use_dns_kdc, _krb5_use_dns_kdc), #else - internals_temp.make_srv_query_realm = 0; - internals_temp.free_srv_dns_data = 0; - internals_temp.use_dns_kdc = 0; + S (make_srv_query_realm, 0), + S (free_srv_dns_data, 0), + S (use_dns_kdc, 0), #endif #ifdef KRB5_KRB4_COMPAT - internals_temp.krb_life_to_time = krb5int_krb_life_to_time; - internals_temp.krb_time_to_life = krb5int_krb_time_to_life; - internals_temp.krb524_encode_v4tkt = krb5int_encode_v4tkt; + S (krb_life_to_time, krb5int_krb_life_to_time), + S (krb_time_to_life, krb5int_krb_time_to_life), + S (krb524_encode_v4tkt, krb5int_encode_v4tkt), +#else + S (krb_life_to_time, 0), + S (krb_time_to_life, 0), + S (krb524_encode_v4tkt, 0), +#endif + S (krb5int_c_mandatory_cksumtype, krb5int_c_mandatory_cksumtype), + S (krb5_ser_pack_int64, krb5_ser_pack_int64), + S (krb5_ser_unpack_int64, krb5_ser_unpack_int64), + S (asn1_ldap_encode_sequence_of_keys, krb5int_ldap_encode_sequence_of_keys), + S (asn1_ldap_decode_sequence_of_keys, krb5int_ldap_decode_sequence_of_keys), +#if DESIGNATED_INITIALIZERS + }; #else - internals_temp.krb_life_to_time = 0; - internals_temp.krb_time_to_life = 0; - internals_temp.krb524_encode_v4tkt = 0; + 0; #endif - internals_temp.krb5int_c_mandatory_cksumtype = krb5int_c_mandatory_cksumtype; - internals_temp.krb5_ser_pack_int64 = krb5_ser_pack_int64; - internals_temp.krb5_ser_unpack_int64 = krb5_ser_unpack_int64; - internals_temp.asn1_ldap_encode_sequence_of_keys = krb5int_ldap_encode_sequence_of_keys; - internals_temp.asn1_ldap_decode_sequence_of_keys = krb5int_ldap_decode_sequence_of_keys; - *internals = internals_temp; - return 0; - } - return KRB5_OBSOLETE_FN; + *internals = internals_temp; + return 0; + } + return KRB5_OBSOLETE_FN; } -- 2.26.2