File: atrd.c

package info (click to toggle)
wv 1.2.9-9
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 5,284 kB
  • sloc: ansic: 31,044; sh: 11,660; xml: 1,677; makefile: 20
file content (128 lines) | stat: -rw-r--r-- 3,384 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/* wvWare
 * Copyright (C) Caolan McNamara, Dom Lachowicz, and others
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
 * 02111-1307, USA.
 */

#ifdef HAVE_CONFIG_H
#include "config.h"
#endif

#include <stdlib.h>
#include <stdio.h>
#include "wv.h"

void
wvGetATRD (ATRD * item, wvStream * fd)
{
    int i;
    for (i = 0; i < 10; i++)
	item->xstUsrInitl[i] = read_16ubit (fd);
    item->ibst = (S16) read_16ubit (fd);
    item->ak = read_16ubit (fd);
    item->grfbmc = read_16ubit (fd);
    item->lTagBkmk = (S32) read_32ubit (fd);
}

int
wvGetATRD_PLCF (ATRD ** atrd, U32 ** pos, U32 * noatrd, U32 offset, U32 len,
		wvStream * fd)
{
    U32 i;
    if (len == 0)
      {
	  *atrd = NULL;
	  *pos = NULL;
	  *noatrd = 0;
      }
    else
      {
	  *noatrd = (len - 4) / (cbATRD + 4);
	  *pos = (U32 *) wvMalloc ((*noatrd + 1) * sizeof (U32));
	  if (*pos == NULL)
	    {
		wvError (
			 ("NO MEM 1, failed to alloc %d bytes\n",
			  (*noatrd + 1) * sizeof (U32)));
		return (1);
	    }

	  *atrd = (ATRD *) wvMalloc ((*noatrd + 1) * sizeof (ATRD));
	  if (*atrd == NULL)
	    {
		wvError (
			 ("NO MEM 1, failed to alloc %d bytes\n",
			  *noatrd * sizeof (ATRD)));
		wvFree (pos);
		return (1);
	    }
	  wvStream_goto (fd, offset);
	  for (i = 0; i < *noatrd + 1; i++)
	      (*pos)[i] = read_32ubit (fd);
	  for (i = 0; i < *noatrd; i++)
	      wvGetATRD (&((*atrd)[i]), fd);
      }
    return (0);
}

ATRD *
wvGetCommentBounds (U32 * comment_cpFirst, U32 * comment_cpLim, U32 currentcp,
		    ATRD * atrd, U32 * pos, U32 noatrd, STTBF * bookmarks,
		    BKF * bkf, U32 * posBKF, U32 bkf_intervals, BKL * bkl,
		    U32 * posBKL, U32 bkl_intervals)
{
    U32 i, j;
    S32 id;

    for (i = 0; i < noatrd; i++)
      {
	  if (pos[i] > currentcp)
	    {
		/*
		   when not -1, this tag identifies the annotation bookmark that locates the
		   range of CPs in the main document which this annotation references.
		 */
		if ((atrd[i].lTagBkmk != -1) && (bookmarks != NULL) && (bookmarks->nostrings > 0) && (bookmarks->extradata))
		  {
		    for (j = 0; j < bookmarks->nostrings; j++)
			{
			    id =
				(S32) sread_32ubit (bookmarks->extradata[j] +
						    2);
			    if (id == atrd[i].lTagBkmk)
			      {
				  wvTrace (("bingo, index is %d!!\n", j));
				  *comment_cpFirst = posBKF[i];
				  *comment_cpLim = posBKL[bkf[i].ibkl];
				  wvTrace (
					   ("begin end are %d %d\n",
					    *comment_cpFirst, *comment_cpLim));
				  return (&(atrd[i]));
			      }
			}
		  }

		/* in case we find nothing, at least we won't blow up, we create a
		   point comment */
		*comment_cpFirst = pos[i];
		*comment_cpLim = pos[i] + 1;
		return (&(atrd[i]));
	    }
      }

    *comment_cpLim = 0xfffffffeL;
    return (NULL);
}