diff options
author | Bodo Möller <bodo@openssl.org> | 2000-09-06 17:40:52 +0200 |
---|---|---|
committer | Bodo Möller <bodo@openssl.org> | 2000-09-06 17:40:52 +0200 |
commit | 61f175f4ba3d90de1fac060080c99aa193764665 (patch) | |
tree | 4773de63fd40fa61569680988becbf7b4ddf5f41 /crypto/asn1 | |
parent | See RSA Security's press release at (diff) | |
download | openssl-61f175f4ba3d90de1fac060080c99aa193764665.tar.xz openssl-61f175f4ba3d90de1fac060080c99aa193764665.zip |
Get rid of ASN1_UTCTIME_get, which cannot work with time_t
return type (on platforms where time_t is a 32 bit value).
New function ASN1_UTCTIME_cmp_time_t as a replacement
for use in apps/x509.c.
Diffstat (limited to 'crypto/asn1')
-rw-r--r-- | crypto/asn1/a_utctm.c | 45 | ||||
-rw-r--r-- | crypto/asn1/asn1.h | 3 |
2 files changed, 48 insertions, 0 deletions
diff --git a/crypto/asn1/a_utctm.c b/crypto/asn1/a_utctm.c index 2ee572e228..b9b4d9a005 100644 --- a/crypto/asn1/a_utctm.c +++ b/crypto/asn1/a_utctm.c @@ -265,6 +265,50 @@ ASN1_UTCTIME *ASN1_UTCTIME_set(ASN1_UTCTIME *s, time_t t) return(s); } + +int ASN1_UTCTIME_cmp_time_t(const ASN1_UTCTIME *s, time_t t) + { + struct tm *tm; + int offset; + int year; + +#define g2(p) (((p)[0]-'0')*10+(p)[1]-'0') + + if (s->data[12] == 'Z') + offset=0; + else + { + offset = g2(s->data+13)*60+g2(s->data+15); + if (s->data[12] == '-') + offset = -offset; + } + + t -= offset*60; /* FIXME: may overflow in extreme cases */ + +#if defined(THREADS) && !defined(WIN32) + { struct tm data; gmtime_r(&t, &data); tm = &data; } +#else + tm = gmtime(&t); +#endif + +#define return_cmp(a,b) if ((a)<(b)) return -1; else if ((a)>(b)) return 1 + year = g2(s->data); + if (year < 50) + year += 100; + return_cmp(year, tm->tm_year); + return_cmp(g2(s->data+2) - 1, tm->tm_mon); + return_cmp(g2(s->data+4), tm->tm_mday); + return_cmp(g2(s->data+6), tm->tm_hour); + return_cmp(g2(s->data+8), tm->tm_min); + return_cmp(g2(s->data+10), tm->tm_sec); +#undef g2 +#undef return_cmp + + return 0; + } + + +#if 0 time_t ASN1_UTCTIME_get(const ASN1_UTCTIME *s) { struct tm tm; @@ -300,3 +344,4 @@ time_t ASN1_UTCTIME_get(const ASN1_UTCTIME *s) * Also time_t is inappropriate for general * UTC times because it may a 32 bit type. */ } +#endif diff --git a/crypto/asn1/asn1.h b/crypto/asn1/asn1.h index b2167561b5..6dfd4fa76e 100644 --- a/crypto/asn1/asn1.h +++ b/crypto/asn1/asn1.h @@ -655,7 +655,10 @@ ASN1_ENUMERATED *d2i_ASN1_ENUMERATED(ASN1_ENUMERATED **a,unsigned char **pp, int ASN1_UTCTIME_check(ASN1_UTCTIME *a); ASN1_UTCTIME *ASN1_UTCTIME_set(ASN1_UTCTIME *s,time_t t); int ASN1_UTCTIME_set_string(ASN1_UTCTIME *s, char *str); +int ASN1_UTCTIME_cmp_time_t(const ASN1_UTCTIME *s, time_t t); +#if 0 time_t ASN1_UTCTIME_get(const ASN1_UTCTIME *s); +#endif int ASN1_GENERALIZEDTIME_check(ASN1_GENERALIZEDTIME *a); ASN1_GENERALIZEDTIME *ASN1_GENERALIZEDTIME_set(ASN1_GENERALIZEDTIME *s,time_t t); |