~ubuntu-branches/ubuntu/jaunty/ghostscript/jaunty-updates

« back to all changes in this revision

Viewing changes to psi/inameidx.h

  • Committer: Bazaar Package Importer
  • Author(s): Till Kamppeter
  • Date: 2009-01-20 16:40:45 UTC
  • mfrom: (1.1.10 upstream)
  • Revision ID: james.westby@ubuntu.com-20090120164045-lnfhi0n30o5lwhwa
Tags: 8.64.dfsg.1~svn9377-0ubuntu1
* New upstream release (SVN rev 9377)
   o Fixes many bugs concerning PDF rendering, to make the PDF printing
     workflow correctly working.
   o Fixes long-standing bugs in many drivers, like input paper tray and
     duplex options not working for the built-in PCL 4, 5, 5c, 5e, and
     6/XL drivers, PDF input not working for bjc600, bjc800, and cups
     output devices, several options not working and uninitialized
     memory with cups output device.
   o Merged nearly all patches of the Ubuntu and Debian packages upstream.
   o Fixes LP: #317810, LP: #314439, LP: #314018.
* debian/patches/03_libpaper_support.dpatch,
  debian/patches/11_gs-cjk_font_glyph_handling_fix.dpatch,
  debian/patches/12_gs-cjk_vertical_writing_metrics_fix.dpatch,
  debian/patches/13_gs-cjk_cjkps_examples.dpatch,
  debian/patches/20_bbox_segv_fix.dpatch,
  debian/patches/21_brother_7x0_gdi_fix.dpatch,
  debian/patches/22_epsn_margin_workaround.dpatch,
  debian/patches/24_gs_man_fix.dpatch,
  debian/patches/25_toolbin_insecure_tmp_usage_fix.dpatch,
  debian/patches/26_assorted_script_fixes.dpatch,
  debian/patches/29_gs_css_fix.dpatch,
  debian/patches/30_ps2pdf_man_improvement.dpatch,
  debian/patches/31_fix-gc-sigbus.dpatch,
  debian/patches/34_ftbfs-on-hurd-fix.dpatch,
  debian/patches/35_disable_libcairo.dpatch,
  debian/patches/38_pxl-duplex.dpatch,
  debian/patches/39_pxl-resolution.dpatch,
  debian/patches/42_gs-init-ps-delaybind-fix.dpatch,
  debian/patches/45_bjc600-bjc800-pdf-input.dpatch,
  debian/patches/48_cups-output-device-pdf-duplex-uninitialized-memory-fix.dpatch,
  debian/patches/50_lips4-floating-point-exception.dpatch,
  debian/patches/52_cups-device-logging.dpatch,
  debian/patches/55_pcl-input-slot-fix.dpatch,
  debian/patches/57_pxl-input-slot-fix.dpatch,
  debian/patches/60_pxl-cups-driver-pdf.dpatch,
  debian/patches/62_onebitcmyk-pdf.dpatch,
  debian/patches/65_too-big-temp-files-1.dpatch,
  debian/patches/67_too-big-temp-files-2.dpatch,
  debian/patches/70_take-into-account-data-in-stream-buffer-before-refill.dpatch:
  Removed, applied upstream.
* debian/patches/01_docdir_fix_for_debian.dpatch,
  debian/patches/02_gs_man_fix_debian.dpatch,
  debian/patches/01_docdir-fix-for-debian.dpatch,
  debian/patches/02_docdir-fix-for-debian.dpatch: Renamed patches to
  make merging with Debian easier.
* debian/patches/32_improve-handling-of-media-size-changes-from-gv.dpatch, 
  debian/patches/33_bad-params-to-xinitimage-on-large-bitmaps.dpatch:
  regenerated for new source directory structure.
* debian/rules: Corrected paths to remove cidfmap (it is in Resource/Init/
  in GS 8.64) and to install headers (source paths are psi/ and base/ now).
* debian/rules: Remove all fontmaps, as DeFoMa replaces them.
* debian/local/pdftoraster/pdftoraster.c,
  debian/local/pdftoraster/pdftoraster.convs, debian/rules: Removed
  added pdftoraster filter and use the one which comes with Ghostscript.
* debian/ghostscript.links: s/8.63/8.64/

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* Copyright (C) 2001-2006 Artifex Software, Inc.
 
2
   All Rights Reserved.
 
3
  
 
4
   This software is provided AS-IS with no warranty, either express or
 
5
   implied.
 
6
 
 
7
   This software is distributed under license and may not be copied, modified
 
8
   or distributed except as expressly authorized under the terms of that
 
9
   license.  Refer to licensing information at http://www.artifex.com/
 
10
   or contact Artifex Software, Inc.,  7 Mt. Lassen Drive - Suite A-134,
 
11
   San Rafael, CA  94903, U.S.A., +1(415)492-9861, for further information.
 
12
*/
 
13
 
 
14
/* $Id: inameidx.h 9043 2008-08-28 22:48:19Z giles $ */
 
15
/* Name index definitions */
 
16
 
 
17
#ifndef inameidx_INCLUDED
 
18
#  define inameidx_INCLUDED
 
19
 
 
20
/*
 
21
 * The name table machinery has two slightly different configurations:
 
22
 * a faster one that limits the total number of names to 64K and allows
 
23
 * names up to 16K in size (EXTEND_NAMES == 0), and a slightly slower
 
24
 * one that limits the total to 64K << EXTEND_NAMES and and restricts names
 
25
 * to 16K >> EXTEND_NAMES. Max value of EXTEND_NAMES is 6, which corresponds
 
26
 * to 4M names of up to to 256 characters.
 
27
 */
 
28
#ifndef EXTEND_NAMES            /* # of bits beyond 16 */
 
29
#  define EXTEND_NAMES 4
 
30
#endif
 
31
 
 
32
/* Define the size of a name sub-table. */
 
33
/* With NT_LOG2_SUB_SIZE >= 10 the subtable goes into a large chunk, */
 
34
/* which names_trace_finish() cannot handle. */
 
35
# define NT_LOG2_SUB_SIZE (8 + (EXTEND_NAMES >= 2)) 
 
36
# define NT_SUB_SIZE (1 << NT_LOG2_SUB_SIZE)
 
37
# define NT_SUB_INDEX_MASK (NT_SUB_SIZE - 1)
 
38
 
 
39
/*
 
40
 * Define the first few entries of the name table.  Entry 0 is left unused.
 
41
 * The entry with count = 1 is the entry for the 0-length name.
 
42
 * The next NT_1CHAR_SIZE entries (in count order) are 1-character names.
 
43
 */
 
44
#define NT_1CHAR_SIZE 128
 
45
#define NT_1CHAR_FIRST 2
 
46
#define NT_1CHAR_NAMES_DATA\
 
47
   0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15,\
 
48
  16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,\
 
49
  32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,\
 
50
  48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,\
 
51
  64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79,\
 
52
  80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95,\
 
53
  96, 97, 98, 99,100,101,102,103,104,105,106,107,108,109,110,111,\
 
54
 112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127
 
55
 
 
56
/* ---------------- Name count/index mapping ---------------- */
 
57
 
 
58
/*
 
59
 * We scramble the assignment order within a sub-table, so that
 
60
 * dictionary lookup doesn't have to scramble the index.
 
61
 * The scrambling algorithm must have three properties:
 
62
 *      - It must map 0 to 0;
 
63
 *      - It must only scramble the sub-table index;
 
64
 *      - It must be a permutation on the sub-table index.
 
65
 * Something very simple works just fine.
 
66
 */
 
67
#define NAME_COUNT_TO_INDEX_FACTOR 23
 
68
#define name_count_to_index(cnt)\
 
69
  (((cnt) & (-NT_SUB_SIZE)) +\
 
70
   (((cnt) * NAME_COUNT_TO_INDEX_FACTOR) & NT_SUB_INDEX_MASK))
 
71
/*
 
72
 * The reverse permutation requires finding a number R such that
 
73
 * NAME_COUNT_TO_INDEX_FACTOR * R = 1 mod NT_SUB_SIZE.
 
74
 * The value given below works for NT_SUB_SIZE any power of 2 up to 4096.
 
75
 * This is not currently used anywhere.
 
76
 */
 
77
#define NAME_INDEX_TO_COUNT_FACTOR 1959
 
78
#define name_index_to_count(nidx)\
 
79
  (((nidx) & (-NT_SUB_SIZE)) +\
 
80
   (((nidx) * NAME_INDEX_TO_COUNT_FACTOR) & NT_SUB_INDEX_MASK))
 
81
 
 
82
#endif /* inameidx_INCLUDED */