mk_ctable.c 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. #include <stdio.h>
  2. typedef struct {
  3. unsigned char c;
  4. unsigned short u;
  5. } charsetItem;
  6. int cmpt(const void *i1, const void *i2)
  7. {
  8. unsigned short u1 = ((charsetItem*)i1) -> u;
  9. unsigned short u2 = ((charsetItem*)i2) -> u;
  10. return (u1 - u2);
  11. }
  12. int main(int argc, char *argv[])
  13. {
  14. unsigned enc, unic;
  15. unsigned i;
  16. charsetItem table[256];
  17. for (i = 0; i < 256; i++) { table[i].c = i, table[i].u = 0; /* unknown */}
  18. while (!feof(stdin))
  19. {
  20. scanf("%i\t%i\n", &enc, &unic);
  21. table[enc].u = unic;
  22. table[enc].c = enc;
  23. if (enc < 128 && enc != unic)
  24. fprintf(stderr, "7bit ASCII incompatibilit (%s): %i->%i\n",
  25. argv[2], enc, unic);
  26. }
  27. /* dump it: */
  28. printf("\n\n"
  29. "/*\n"
  30. " * %s to Unicode recoding table\n"
  31. " * based on file %s by Unicode Consortium\n"
  32. " */\n\n"
  33. "static const wxUint16 encoding_table__%s[128] = {",
  34. argv[2], argv[1], argv[2]);
  35. for (i = 128; i < 256; i++)
  36. {
  37. if (i % 8 == 0)
  38. printf("\n ");
  39. printf(" 0x%04X%c", table[i].u, (i == 255) ? '\n' : ',');
  40. }
  41. printf(" };\n");
  42. qsort(table + 128, 128, sizeof(table[0]), cmpt);
  43. /*
  44. NO, WE DON'T NEED REVERSE TABLE, WE CAN BUILD IT AT RUNTIME
  45. (won't take that much time, after all you don't init
  46. conversion so often...)
  47. printf("\n"
  48. "static wxUint16 encoding_table_rev__%s[128] = {",
  49. argv[2]);
  50. for (i = 128; i < 256; i++)
  51. {
  52. if (i % 4 == 0)
  53. printf("\n ");
  54. printf("{c:0x%02X,u:0x%04X}%c ", table[i].c, table[i].u, (i == 255) ? '\n' : ',');
  55. }
  56. printf("};\n");
  57. */
  58. return 1;
  59. }