# HG changeset patch # User Mychaela Falconia # Date 1691214315 0 # Node ID b831ee7d512c0e792432bc1e51502f509110a835 # Parent c79d09284c5fe7f6aa06efe579baadf37b900600 libcoding: add absolute time encoding function diff -r c79d09284c5f -r b831ee7d512c libcoding/Makefile --- a/libcoding/Makefile Sat Aug 05 03:20:11 2023 +0000 +++ b/libcoding/Makefile Sat Aug 05 05:45:15 2023 +0000 @@ -1,7 +1,7 @@ CC= gcc CFLAGS= -O2 OBJS= gsm7_encode.o gsm7_encode_table.o gsm7_pack.o hexout.o number_encode.o \ - ucs2_bigend.o utf8_decode.o utf8_decode2.o + timestamp.o ucs2_bigend.o utf8_decode.o utf8_decode2.o LIB= libcoding.a all: ${LIB} diff -r c79d09284c5f -r b831ee7d512c libcoding/timestamp.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libcoding/timestamp.c Sat Aug 05 05:45:15 2023 +0000 @@ -0,0 +1,61 @@ +/* + * The function implemented in this module encodes a GSM SMS absolute timestamp + * from ASCII representation into PDU octets. + */ + +#include +#include + +encode_gsm_sms_abstime(str, bin) + char *str; + u_char *bin; +{ + u_char digits[14]; + + if (!isdigit(str[0]) || !isdigit(str[1])) + return(-1); + digits[0] = str[0] - '0'; + digits[1] = str[1] - '0'; + if (str[2] != '/') + return(-1); + if (!isdigit(str[3]) || !isdigit(str[4])) + return(-1); + digits[2] = str[3] - '0'; + digits[3] = str[4] - '0'; + if (str[5] != '/') + return(-1); + if (!isdigit(str[6]) || !isdigit(str[7])) + return(-1); + digits[4] = str[6] - '0'; + digits[5] = str[7] - '0'; + if (str[8] != ',') + return(-1); + if (!isdigit(str[9]) || !isdigit(str[10])) + return(-1); + digits[6] = str[9] - '0'; + digits[7] = str[10] - '0'; + if (str[11] != ':') + return(-1); + if (!isdigit(str[12]) || !isdigit(str[13])) + return(-1); + digits[8] = str[12] - '0'; + digits[9] = str[13] - '0'; + if (str[14] != ':') + return(-1); + if (!isdigit(str[15]) || !isdigit(str[16])) + return(-1); + digits[10] = str[15] - '0'; + digits[11] = str[16] - '0'; + if (str[17] != '+' && str[17] != '-') + return(-1); + if (!isdigit(str[18]) || !isdigit(str[19])) + return(-1); + digits[12] = str[18] - '0'; + digits[13] = str[19] - '0'; + if (str[20]) + return(-1); + if (str[17] == '-') + digits[12] |= 8; + pack_digit_bytes(digits, bin, 7); + return(0); +}