FreeCalypso > hg > themwi-system-sw
annotate libutil/imsi_entry.c @ 194:05d01e810217
libutil: add TFO message gen function based on Osmocom crc8gen
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 17 Mar 2023 16:52:21 -0800 |
parents | 40e5097437fa |
children |
rev | line source |
---|---|
19
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 /* |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
2 * The library function implemented in this module supports IMSI entry |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
3 * at UI level, either in the standard form (long string of digits) |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
4 * or in the shorthand notation introduced in fc-sim-tools. |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
5 */ |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
6 |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
7 #include <ctype.h> |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
8 #include <string.h> |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
9 #include <strings.h> |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
11 grok_imsi_user_arg(arg, dest) |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 char *arg, *dest; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 { |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 char *cp, *dp; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 int n, tail_len, remain; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
16 |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
17 if (!isdigit(*arg)) |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
18 return(-1); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
19 cp = arg; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
20 dp = dest; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
21 n = 0; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
22 while (isdigit(*cp)) { |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
23 if (n >= 15) |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
24 return(-1); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
25 *dp++ = *cp++; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
26 n++; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
27 } |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
28 if (!*cp) { |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
29 if (n < 6) |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
30 return(-1); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
31 *dp = '\0'; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
32 return(0); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
33 } |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
34 if (*cp != '-') |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
35 return(-1); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
36 cp++; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
37 tail_len = strlen(cp); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
38 if (!tail_len) |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
39 return(-1); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
40 remain = 15 - n; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
41 if (remain < tail_len + 1) |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
42 return(-1); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
43 while (remain > tail_len) { |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
44 *dp++ = '0'; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
45 remain--; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
46 } |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
47 while (*cp) { |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
48 if (!isdigit(*cp)) |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
49 return(-1); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
50 *dp++ = *cp++; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
51 } |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
52 *dp = '\0'; |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
53 return(0); |
40e5097437fa
libutil: add grok_imsi_user_arg()
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
54 } |