cod2txt.c 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * Copyright 1992 by Jutta Degener and Carsten Bormann, Technische
  3. * Universitaet Berlin. See the accompanying file "COPYRIGHT" for
  4. * details. THERE IS ABSOLUTELY NO WARRANTY FOR THIS SOFTWARE.
  5. */
  6. /*$Header: /tmp_amd/presto/export/kbs/jutta/src/gsm/RCS/cod2txt.c,v 1.1 1994/10/21 20:52:11 jutta Exp $*/
  7. #include <stdio.h>
  8. #include <assert.h>
  9. #include "gsm.h"
  10. #include "proto.h"
  11. char * pname;
  12. int debug = 0;
  13. int verbosity = 0;
  14. int error = 0;
  15. usage P0()
  16. {
  17. fprintf(stderr, "Usage: %s [files...]\n", pname);
  18. exit(1);
  19. }
  20. void process P2((f, filename), FILE * f, char * filename)
  21. {
  22. gsm_frame buf;
  23. gsm_signal source[160];
  24. int cc;
  25. gsm r;
  26. int nr=0;
  27. (void)memset(source, 0, sizeof(source));
  28. if (!(r = gsm_create())) {
  29. perror("gsm_create");
  30. error = 1;
  31. return ;
  32. }
  33. gsm_option(r, GSM_OPT_VERBOSE, &verbosity);
  34. for (;;) {
  35. cc = fread((char *)source, sizeof(*source), 76, f);
  36. if (cc == 0) {
  37. gsm_destroy(r);
  38. return;
  39. }
  40. if (cc != 76) {
  41. error = 1;
  42. fprintf(stderr,
  43. "%s: %s -- %d trailing bytes ignored\n",
  44. pname, filename, cc);
  45. gsm_destroy(r);
  46. return;
  47. }
  48. gsm_implode(r, source, buf);
  49. printf("[%d] ", ++nr);
  50. if (gsm_print(stdout, r, buf)) {
  51. fprintf(stderr,
  52. "%s: %s: bad magic\n", pname, filename);
  53. gsm_destroy(r);
  54. return;
  55. }
  56. }
  57. }
  58. main P2((ac, av), int ac, char ** av)
  59. {
  60. int opt;
  61. extern char * optarg;
  62. extern int optind;
  63. FILE * f;
  64. if (!(pname = av[0])) pname = "cod2txt";
  65. ac--;
  66. av++;
  67. if (!ac) process(stdin, "*stdin*");
  68. else for (; *av; av++) {
  69. if (!(f = fopen(*av, "r"))) perror(*av);
  70. else {
  71. process(f, *av);
  72. fclose(f);
  73. }
  74. }
  75. exit(error);
  76. }