FreeCalypso > hg > gsm-codec-lib
comparison libtest/tw5reader.c @ 522:4d2cccaeb4a7
libtest: implement TW-TS-005 reader function
Spec reference:
https://www.freecalypso.org/specs/tw-ts-005-v010002.txt
| author | Mychaela Falconia <falcon@freecalypso.org> |
|---|---|
| date | Thu, 19 Sep 2024 03:08:47 +0000 |
| parents | libtest/binreader.c@820d88b97924 |
| children | 3c6bf0d26ee7 |
comparison
equal
deleted
inserted
replaced
| 521:68fe269b4316 | 522:4d2cccaeb4a7 |
|---|---|
| 1 /* | |
| 2 * Here we implement our twts005_read_frame() function. | |
| 3 */ | |
| 4 | |
| 5 #include <ctype.h> | |
| 6 #include <stdio.h> | |
| 7 #include <stdint.h> | |
| 8 #include <string.h> | |
| 9 #include <strings.h> | |
| 10 #include "tw5reader.h" | |
| 11 | |
| 12 static int decode_hex_digit(char c) | |
| 13 { | |
| 14 if (isdigit(c)) | |
| 15 return c - '0'; | |
| 16 else if (isupper(c)) | |
| 17 return c - 'A' + 10; | |
| 18 else | |
| 19 return c - 'a' + 10; | |
| 20 } | |
| 21 | |
| 22 int twts005_read_frame(FILE *hexf, unsigned *lineno, uint8_t *frame, | |
| 23 unsigned *lenp) | |
| 24 { | |
| 25 char linebuf[81]; | |
| 26 char *cp, *np; | |
| 27 uint8_t *dp; | |
| 28 unsigned len; | |
| 29 | |
| 30 for (;;) { | |
| 31 if (!fgets(linebuf, sizeof linebuf, hexf)) | |
| 32 return 0; | |
| 33 (*lineno)++; | |
| 34 if (!index(linebuf, '\n')) | |
| 35 return -2; | |
| 36 for (cp = linebuf; isspace(*cp); cp++) | |
| 37 ; | |
| 38 if (*cp != '\0' && *cp != '#') | |
| 39 break; | |
| 40 } | |
| 41 for (np = cp; *cp && !isspace(*cp); cp++) | |
| 42 ; | |
| 43 if (*cp) | |
| 44 *cp++ = '\0'; | |
| 45 while (isspace(*cp)) | |
| 46 cp++; | |
| 47 if (*cp != '\0' && *cp != '#') | |
| 48 return -1; | |
| 49 if (!strcasecmp(np, "NULL")) { | |
| 50 *lenp = 0; | |
| 51 return 1; | |
| 52 } | |
| 53 | |
| 54 dp = frame; | |
| 55 len = 0; | |
| 56 for (cp = np; *cp; cp += 2) { | |
| 57 if (!isxdigit(cp[0]) || !isxdigit(cp[1])) | |
| 58 return -1; | |
| 59 *dp++ = (decode_hex_digit(cp[0]) << 4) | | |
| 60 decode_hex_digit(cp[1]); | |
| 61 len++; | |
| 62 } | |
| 63 *lenp = len; | |
| 64 return 1; | |
| 65 } |
