FreeCalypso > hg > freecalypso-hwlab
view simtool/dispatch.c @ 136:a21d348e01db
fc-uicc-tool: pb-dump command ported over
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Thu, 04 Feb 2021 03:40:55 +0000 |
parents | 2adb802b2a98 |
children | 431194b772e1 |
line wrap: on
line source
/* * This module implements the command dispatch for fc-simtool */ #include <ctype.h> #include <stdio.h> #include <string.h> #include <strings.h> #include <stdlib.h> extern int cmd_a38(); extern int cmd_change_chv(); extern int cmd_disable_chv(); extern int cmd_enable_chv(); extern int cmd_exec(); extern int cmd_fix_sysmo_msisdn(); extern int cmd_iccid(); extern int cmd_imsi(); extern int cmd_pb_dump(); extern int cmd_pb_dump_rec(); extern int cmd_pb_erase(); extern int cmd_pb_erase_one(); extern int cmd_pb_erase_range(); extern int cmd_pb_update(); extern int cmd_pb_update_imm(); extern int cmd_pb_update_imm_hex(); extern int cmd_readbin(); extern int cmd_readef(); extern int cmd_readrec(); extern int cmd_restore_file(); extern int cmd_savebin(); extern int cmd_save_sms_bin(); extern int cmd_select(); extern int cmd_spn(); extern int cmd_telecom_sum(); extern int cmd_unblock_chv(); extern int cmd_update_bin(); extern int cmd_update_bin_imm(); extern int cmd_update_rec(); extern int cmd_verify_chv(); extern int cmd_verify_ext(); extern int display_sim_resp_in_hex(); extern int good_exit(); static struct cmdtab { char *cmd; int minargs; int maxargs; int (*func)(); } cmdtab[] = { {"a38", 1, 1, cmd_a38}, {"change-chv1", 2, 2, cmd_change_chv}, {"change-chv2", 2, 2, cmd_change_chv}, {"change-pin1", 2, 2, cmd_change_chv}, {"change-pin2", 2, 2, cmd_change_chv}, {"disable-chv", 1, 1, cmd_disable_chv}, {"disable-pin", 1, 1, cmd_disable_chv}, {"enable-chv", 1, 1, cmd_enable_chv}, {"enable-pin", 1, 1, cmd_enable_chv}, {"exec", 1, 1, cmd_exec}, {"exit", 0, 0, good_exit}, {"fix-sysmo-msisdn", 0, 0, cmd_fix_sysmo_msisdn}, {"iccid", 0, 0, cmd_iccid}, {"imsi", 0, 0, cmd_imsi}, {"pb-dump", 1, 2, cmd_pb_dump}, {"pb-dump-rec", 2, 3, cmd_pb_dump_rec}, {"pb-erase", 1, 1, cmd_pb_erase}, {"pb-erase-one", 2, 2, cmd_pb_erase_one}, {"pb-erase-range", 3, 3, cmd_pb_erase_range}, {"pb-update", 2, 2, cmd_pb_update}, {"pb-update-imm", 3, 4, cmd_pb_update_imm}, {"pb-update-imm-hex", 4, 4, cmd_pb_update_imm_hex}, {"quit", 0, 0, good_exit}, {"readbin", 2, 2, cmd_readbin}, {"readef", 1, 1, cmd_readef}, {"readrec", 1, 2, cmd_readrec}, {"restore-file", 2, 2, cmd_restore_file}, {"savebin", 2, 2, cmd_savebin}, {"save-sms-bin", 1, 1, cmd_save_sms_bin}, {"select", 1, 1, cmd_select}, {"sim-resp", 0, 0, display_sim_resp_in_hex}, {"spn", 0, 0, cmd_spn}, {"telecom-sum", 0, 0, cmd_telecom_sum}, {"unblock-chv1", 2, 2, cmd_unblock_chv}, {"unblock-chv2", 2, 2, cmd_unblock_chv}, {"unblock-pin1", 2, 2, cmd_unblock_chv}, {"unblock-pin2", 2, 2, cmd_unblock_chv}, {"update-bin", 2, 2, cmd_update_bin}, {"update-bin-imm", 2, 2, cmd_update_bin_imm}, {"update-rec", 2, 2, cmd_update_rec}, {"verify-chv1", 1, 1, cmd_verify_chv}, {"verify-chv2", 1, 1, cmd_verify_chv}, {"verify-ext", 2, 2, cmd_verify_ext}, {"verify-pin1", 1, 1, cmd_verify_chv}, {"verify-pin2", 1, 1, cmd_verify_chv}, {0, 0, 0, 0} }; simtool_dispatch_cmd(cmd, is_script) char *cmd; { char *argv[10]; char *cp, **ap; struct cmdtab *tp; for (cp = cmd; isspace(*cp); cp++) ; if (!*cp || *cp == '#') return(0); if (is_script) printf("Script command: %s\n", cp); argv[0] = cp; while (*cp && !isspace(*cp)) cp++; if (*cp) *cp++ = '\0'; for (tp = cmdtab; tp->cmd; tp++) if (!strcmp(tp->cmd, argv[0])) break; if (!tp->func) { fprintf(stderr, "error: no such command\n"); return(-1); } for (ap = argv + 1; ; ) { while (isspace(*cp)) cp++; if (!*cp || *cp == '#') break; if (ap - argv - 1 >= tp->maxargs) { fprintf(stderr, "error: too many arguments\n"); return(-1); } if (*cp == '"') { *ap++ = ++cp; for (;;) { if (!*cp) { unterm_qstring: fprintf(stderr, "error: unterminated quoted string\n"); return(-1); } if (*cp == '"') break; if (*cp++ == '\\') { if (!*cp) goto unterm_qstring; cp++; } } *cp++ = '\0'; } else { *ap++ = cp; while (*cp && !isspace(*cp)) cp++; if (*cp) *cp++ = '\0'; } } if (ap - argv - 1 < tp->minargs) { fprintf(stderr, "error: too few arguments\n"); return(-1); } *ap = 0; return tp->func(ap - argv, argv); } dispatch_ready_argv(argc, argv) char **argv; { struct cmdtab *tp; for (tp = cmdtab; tp->cmd; tp++) if (!strcmp(tp->cmd, argv[0])) break; if (!tp->func) { fprintf(stderr, "error: no such command\n"); return(-1); } if (argc - 1 > tp->maxargs) { fprintf(stderr, "error: too many arguments\n"); return(-1); } if (argc - 1 < tp->minargs) { fprintf(stderr, "error: too few arguments\n"); return(-1); } return tp->func(argc, argv); }