From 463e8dcac4a2f724a58dae7ea57dd600b8f8a2ef Mon Sep 17 00:00:00 2001 From: Werner Almesberger Date: Wed, 11 Jul 2012 23:52:54 -0300 Subject: [PATCH] gencat/pdf.c: key index entries by the tree node, to distinguish duplicates Before, duplicate names in the tree always pointed to the same page. Now they point to the respective locations. Note that this does not affect handling of duplicate names in libraries, where still only one "wins" while the other is completely ignored. --- gencat/pdf.c | 33 +++++++++++++++++++++++---------- 1 file changed, 23 insertions(+), 10 deletions(-) diff --git a/gencat/pdf.c b/gencat/pdf.c index bb411a5..8aa4378 100644 --- a/gencat/pdf.c +++ b/gencat/pdf.c @@ -89,7 +89,13 @@ static void ps_string(FILE *file, const char *s) /* ----- Alphabetic index -------------------------------------------------- */ -static void collect_names(const struct node *node, const char ***idx, int *n) +struct index { + const char *s; + const struct node *node; +}; + + +static void collect_names(const struct node *node, struct index **idx, int *n) { const struct name *name; @@ -99,10 +105,11 @@ static void collect_names(const struct node *node, const char ***idx, int *n) else { for (name = node->e->names; name; name = name->next) { (*n)++; - *idx = realloc(*idx, *n*sizeof(char *)); + *idx = realloc(*idx, *n*sizeof(struct entry)); if (!*idx) abort(); - (*idx)[*n-1] = name->s; + (*idx)[*n-1].s = name->s; + (*idx)[*n-1].node = node; } } node = node->next; @@ -112,18 +119,22 @@ static void collect_names(const struct node *node, const char ***idx, int *n) static int comp(const void *a, const void *b) { - return strcmp(*(const char **) a, *(const char **) b); + const struct index *ai = a; + const struct index *bi = b; + + return strcmp(ai->s, bi->s); } static void make_index(FILE *file, const struct node *node) { - const char **idx = NULL, **p; + struct index *idx = NULL; + const struct index *p; int n = 0; int line = 0, col = 0; collect_names(node, &idx, &n); - qsort(idx, n, sizeof(char *), comp); + qsort(idx, n, sizeof(struct index), comp); fprintf(file, "[ /Title (Index) /Count 0 /OUT pdfmark\n"); @@ -147,15 +158,16 @@ static void make_index(FILE *file, const struct node *node) format.index.y+line*format.index_line_skip); fprintf(file, "[ /Rect [ "); - ps_string(file, *p); + ps_string(file, p->s); fprintf(file, " false charpath flattenpath pathbbox ]\n"); fprintf(file, " /Subtype /Link\n"); fprintf(file, " /Border [ 0 0 0 ]\n"); - fprintf(file, " /Action << /Subtype /GoTo /Dest /%p >>\n", *p); + fprintf(file, " /Action << /Subtype /GoTo /Dest /%p%p >>\n", + p->node, p->s); fprintf(file, " /ANN pdfmark\n"); fprintf(file, "moveto "); - ps_string(file, *p); + ps_string(file, p->s); fprintf(file, " show\n"); line++; } @@ -206,7 +218,8 @@ static void make_title(FILE *file, const struct node *node, int unit) ps_string(file, name->s); fprintf(file, " show\n"); if (!unit) - fprintf(file, "[ /Dest /%p /DEST pdfmark\n", name->s); + fprintf(file, "[ /Dest /%p%p /DEST pdfmark\n", + node, name->s); } fprintf(file, "0 setgray\n"); if (node->e->units > 1)