inamestr.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. /* Copyright (C) 1999 Aladdin Enterprises. All rights reserved.
  2. This software is provided AS-IS with no warranty, either express or
  3. implied.
  4. This software is distributed under license and may not be copied,
  5. modified or distributed except as expressly authorized under the terms
  6. of the license contained in the file LICENSE in this distribution.
  7. For more information about licensing, please refer to
  8. http://www.ghostscript.com/licensing/. For information on
  9. commercial licensing, go to http://www.artifex.com/licensing/ or
  10. contact Artifex Software, Inc., 101 Lucas Valley Road #110,
  11. San Rafael, CA 94903, U.S.A., +1(415)492-9861.
  12. */
  13. /* $Id: inamestr.h,v 1.4 2002/02/21 22:24:53 giles Exp $ */
  14. /* Name table strings definition */
  15. #ifndef inamestr_INCLUDED
  16. # define inamestr_INCLUDED
  17. #include "inameidx.h"
  18. /*
  19. * In the code below, we use the hashing method described in
  20. * "Fast Hashing of Variable-Length Text Strings" by Peter K. Pearson,
  21. * pp. 677-680, CACM 33(6), June 1990.
  22. */
  23. /*
  24. * Define a pseudo-random permutation of the integers 0..255.
  25. * Pearson's article claims this permutation gave good results.
  26. */
  27. #define NAME_HASH_PERMUTATION_DATA\
  28. 1, 87, 49, 12, 176, 178, 102, 166, 121, 193, 6, 84, 249, 230, 44, 163,\
  29. 14, 197, 213, 181, 161, 85, 218, 80, 64, 239, 24, 226, 236, 142, 38, 200,\
  30. 110, 177, 104, 103, 141, 253, 255, 50, 77, 101, 81, 18, 45, 96, 31, 222,\
  31. 25, 107, 190, 70, 86, 237, 240, 34, 72, 242, 20, 214, 244, 227, 149, 235,\
  32. 97, 234, 57, 22, 60, 250, 82, 175, 208, 5, 127, 199, 111, 62, 135, 248,\
  33. 174, 169, 211, 58, 66, 154, 106, 195, 245, 171, 17, 187, 182, 179, 0, 243,\
  34. 132, 56, 148, 75, 128, 133, 158, 100, 130, 126, 91, 13, 153, 246, 216, 219,\
  35. 119, 68, 223, 78, 83, 88, 201, 99, 122, 11, 92, 32, 136, 114, 52, 10,\
  36. 138, 30, 48, 183, 156, 35, 61, 26, 143, 74, 251, 94, 129, 162, 63, 152,\
  37. 170, 7, 115, 167, 241, 206, 3, 150, 55, 59, 151, 220, 90, 53, 23, 131,\
  38. 125, 173, 15, 238, 79, 95, 89, 16, 105, 137, 225, 224, 217, 160, 37, 123,\
  39. 118, 73, 2, 157, 46, 116, 9, 145, 134, 228, 207, 212, 202, 215, 69, 229,\
  40. 27, 188, 67, 124, 168, 252, 42, 4, 29, 108, 21, 247, 19, 205, 39, 203,\
  41. 233, 40, 186, 147, 198, 192, 155, 33, 164, 191, 98, 204, 165, 180, 117, 76,\
  42. 140, 36, 210, 172, 41, 54, 159, 8, 185, 232, 113, 196, 231, 47, 146, 120,\
  43. 51, 65, 28, 144, 254, 221, 93, 189, 194, 139, 112, 43, 71, 109, 184, 209
  44. /* Compute the hash for a name string. Assume size >= 1. */
  45. #define NAME_HASH(hash, hperm, ptr, size)\
  46. BEGIN\
  47. const byte *p = ptr;\
  48. uint n = size;\
  49. \
  50. hash = hperm[*p++];\
  51. while (--n > 0)\
  52. hash = (hash << 8) | hperm[(byte)hash ^ *p++];\
  53. END
  54. /*
  55. * Define the structure for a name string. The next_index "pointer" is used
  56. * both for the chained hash table in the name_table and for the list of
  57. * free names.
  58. */
  59. typedef struct name_string_s {
  60. #if EXTEND_NAMES
  61. # define name_extension_bits 6
  62. #else
  63. # define name_extension_bits 0
  64. #endif
  65. unsigned next_index:16 + name_extension_bits; /* next name in chain or 0 */
  66. unsigned foreign_string:1; /* string is allocated statically */
  67. unsigned mark:1; /* GC mark bit of index for this name */
  68. #define name_string_size_bits (14 - name_extension_bits)
  69. #define max_name_string ((1 << name_string_size_bits) - 1)
  70. unsigned string_size:name_string_size_bits;
  71. const byte *string_bytes;
  72. } name_string_t;
  73. #define name_next_index(nidx, pnstr)\
  74. ((pnstr)->next_index)
  75. #define set_name_next_index(nidx, pnstr, next)\
  76. ((pnstr)->next_index = (next))
  77. /* Define a sub-table of name strings. */
  78. typedef struct name_string_sub_table_s {
  79. name_string_t strings[NT_SUB_SIZE];
  80. } name_string_sub_table_t;
  81. /* Define the size of the name hash table. */
  82. #define NT_HASH_SIZE (1024 << (EXTEND_NAMES / 2)) /* must be a power of 2 */
  83. #endif /* inamestr_INCLUDED */