File: edfile.h

package info (click to toggle)
cuneiform 1.1.0%2Bdfsg-9
  • links: PTS
  • area: non-free
  • in suites: bookworm
  • size: 71,808 kB
  • sloc: ansic: 183,506; cpp: 101,929; makefile: 82; sh: 59
file content (399 lines) | stat: -rw-r--r-- 13,958 bytes parent folder | download | duplicates (7)
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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
/*
Copyright (c) 1993-2008, Cognitive Technologies
All rights reserved.

Разрешается повторное распространение и использование как в виде исходного кода,
так и в двоичной форме, с изменениями или без, при соблюдении следующих условий:

      * При повторном распространении исходного кода должны оставаться указанное
        выше уведомление об авторском праве, этот список условий и последующий
        отказ от гарантий.
      * При повторном распространении двоичного кода в документации и/или в
        других материалах, поставляемых при распространении, должны сохраняться
        указанная выше информация об авторском праве, этот список условий и
        последующий отказ от гарантий.
      * Ни название Cognitive Technologies, ни имена ее сотрудников не могут
        быть использованы в качестве средства поддержки и/или продвижения
        продуктов, основанных на этом ПО, без предварительного письменного
        разрешения.

ЭТА ПРОГРАММА ПРЕДОСТАВЛЕНА ВЛАДЕЛЬЦАМИ АВТОРСКИХ ПРАВ И/ИЛИ ДРУГИМИ ЛИЦАМИ "КАК
ОНА ЕСТЬ" БЕЗ КАКОГО-ЛИБО ВИДА ГАРАНТИЙ, ВЫРАЖЕННЫХ ЯВНО ИЛИ ПОДРАЗУМЕВАЕМЫХ,
ВКЛЮЧАЯ ГАРАНТИИ КОММЕРЧЕСКОЙ ЦЕННОСТИ И ПРИГОДНОСТИ ДЛЯ КОНКРЕТНОЙ ЦЕЛИ, НО НЕ
ОГРАНИЧИВАЯСЬ ИМИ. НИ ВЛАДЕЛЕЦ АВТОРСКИХ ПРАВ И НИ ОДНО ДРУГОЕ ЛИЦО, КОТОРОЕ
МОЖЕТ ИЗМЕНЯТЬ И/ИЛИ ПОВТОРНО РАСПРОСТРАНЯТЬ ПРОГРАММУ, НИ В КОЕМ СЛУЧАЕ НЕ
НЕСЁТ ОТВЕТСТВЕННОСТИ, ВКЛЮЧАЯ ЛЮБЫЕ ОБЩИЕ, СЛУЧАЙНЫЕ, СПЕЦИАЛЬНЫЕ ИЛИ
ПОСЛЕДОВАВШИЕ УБЫТКИ, СВЯЗАННЫЕ С ИСПОЛЬЗОВАНИЕМ ИЛИ ПОНЕСЕННЫЕ ВСЛЕДСТВИЕ
НЕВОЗМОЖНОСТИ ИСПОЛЬЗОВАНИЯ ПРОГРАММЫ (ВКЛЮЧАЯ ПОТЕРИ ДАННЫХ, ИЛИ ДАННЫЕ,
СТАВШИЕ НЕГОДНЫМИ, ИЛИ УБЫТКИ И/ИЛИ ПОТЕРИ ДОХОДОВ, ПОНЕСЕННЫЕ ИЗ-ЗА ДЕЙСТВИЙ
ТРЕТЬИХ ЛИЦ И/ИЛИ ОТКАЗА ПРОГРАММЫ РАБОТАТЬ СОВМЕСТНО С ДРУГИМИ ПРОГРАММАМИ,
НО НЕ ОГРАНИЧИВАЯСЬ ЭТИМИ СЛУЧАЯМИ), НО НЕ ОГРАНИЧИВАЯСЬ ИМИ, ДАЖЕ ЕСЛИ ТАКОЙ
ВЛАДЕЛЕЦ ИЛИ ДРУГОЕ ЛИЦО БЫЛИ ИЗВЕЩЕНЫ О ВОЗМОЖНОСТИ ТАКИХ УБЫТКОВ И ПОТЕРЬ.

Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:

    * Redistributions of source code must retain the above copyright notice,
      this list of conditions and the following disclaimer.
    * Redistributions in binary form must reproduce the above copyright notice,
      this list of conditions and the following disclaimer in the documentation
      and/or other materials provided with the distribution.
    * Neither the name of the Cognitive Technologies nor the names of its
      contributors may be used to endorse or promote products derived from this
      software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/


#ifndef __EDFILE__
#define __EDFILE__

#include "globus.h"
#pragma pack(push,1)

#define SS_BITMAP_REF 0x00
#define SS_TEXT_REF 0x01
#define SS_REMARK SS_TEXT_REF
#define SS_FONT_KEGL 0x02
#define SS_KEGL 0x03
#define SS_SHIFT 0x04
#define SS_RETR_LEVEL 0x05
#define SS_UNDERLINE 0x06
#define SS_DENS_PRINT 0x07
#define SS_TABUL 0x08
#define SS_TABL_TABUL 0x09
#define SS_SHEET_DESCR 0x0a
#define SS_FRAGMENT 0x0b
#define SS_STEP_BACK 0x0c
#define SS_LINE_BEG 0x0d
#define SS_POSITION 0x0e
#define SS_LANGUAGE 0x0f
#define SS_TABL_CONFORM_SIZES 0x10
#define SS_GROUP_WORDS 0x11
#define SS_GROUP_SYMBOLS 0x12
#define SS_PARAGRAPH	 0x15
#define SS_BORDER        0x16
#define SS_TABLE_HEADER  0x17
#define SS_LIST_OF_FRAGMENTS 0x18
//  SS_EXTENTION	0x1C  Specian code for Extention ED format see EDEXT.H
#define SS_AKSANT 0x1d
#define SS_NEG_HALF_SPACE 0x1e
#define SS_POS_HALF_SPACE 0x1f

struct bit_map_ref
 {
 uchar code;
 uchar pos;
 uint16_t row;
 uint16_t col;
 uint16_t width;
 uint16_t height;
 };

struct text_ref
 {                                     /* 0 - letter */
 uchar code;                            /* 1 -        */
 uchar type;                            /* 2 - word   */
 uint16_t object;                           /* 3 - string */
 };

struct font_kegl                       /*  1 - serific     */
 {                                     /*  2 - gelvetic    */
 uchar code;                            /*  4 - bold        */
 uchar new_kegl;                        /*  8 - light       */
 uint16_t new_font;                        /* 16 - italic      */
// uchar reserv;                          /* 32 - straight    */
 };                                    /* 64 - underlined  */

struct kegl
 {
 uchar code;
 uchar new_kegl;
 };

struct EdTagLanguage //for russian-english recognize
 {
 uchar code; // 0x0F
 uchar language;
 };

struct shift
 {
 uchar code;
 uchar kegl;
 uint16_t clearance;                         /* value of lift or descent */
 };                                     /* lift positive            */
					/* descent negative         */
struct retrieve_level
 {
 uchar code;
 uchar kegl;
 };

struct underline
 {                                     /* 0 - thin straight       */
 uchar code;                            /* 1- half thick straight  */
 uchar type;                            /* 2- thick straight       */
 };                                    /* 3- thin cursive         */
				       /* 4- half thick cursive   */
				       /* 5- thick cursive        */
				       /* 6- beg of underline     */
				       /* 7- end of underline     */
struct dens_print
 {
 uchar code;
 uchar dens_atr;                         /* attribute of print's    */
 };				        /*                 density */

struct tabul
 {
 uchar code;
 uchar numb_in_tab_tabul;                /* number of position in        */
 };                                     /*         table of tabulation  */

struct tabl_tabul
 {
 uchar code;
 uchar lth;                              /* scale of arow               */
 uint16_t arow_pos[1] ;
 };

struct fragm_disk
 {
 uchar code;
 uchar fragm_numb;
 uint16_t depth;
 };

struct step_back
 {
 uchar code;
 uchar Step_back;                        // value of backstep //AK 18.03.97 step -> Step
 };

struct line_beg
 {
 uchar code;
 uchar height;
 uint16_t base_line;                         /* displacement for current         */
 };                                     /*     line to upper frame of fragm */

struct position
 {
 uchar code;
 uchar store;
 uint16_t pos;                               /* position in line for      */
 };                                     /*     left frame of  fragm  */

struct table_conform_sizes
 {
 uchar code;
 uchar store;
 char tab_val_A [9*2];                   /* table of sizes of letter A  */
 };              			 /*     for kegles from 4 to 12 */


struct group_words
 {
 uchar code;
 uchar  gr_wd_type;                     	  /* 0 - beg of group             */
 };			                  /* 1 - cur. word of group       */
					  /* 2 - end                      */
					  /* 3 - partition between groups */

struct group_symbols
 {
 uchar code;
 uchar gr_sb_type;
 };

struct border
    {
    uchar code;          /* 0x16 SS_BORDER             */
    uchar type;          /* 1 - left                   */
#define b_vert 1	/* 2 - right                  */
#define b_hor  4	/* 4 - top                    */
			/* 8 - bottom                 */
    uint16_t  length;        /* Length of border in pixels */
    uint16_t  x,y;           /* Coordinates of line begin  */
    };

struct table_header
    {
    uchar    code;       /* 0x17 SS_TABLE_HEADER                   */
    uchar    cols;       /* Number of columns                      */
    uint16_t     lth;        /* Total length of record                 */
    uint16_t     nfrag[1];    /* List of fragments in header of table   */
    };

struct list_of_fragments
    {
    uchar    code;       /* 0x18 SS_LIST_OF_FRAGMENTS    */
    uchar    cols;       /* Number of columns            */
    uint16_t     lth;        /* Total length of record       */
    uint16_t     nfrag[1];   /* List of fragments in table   */
    };

struct aksant
 {
 uchar code1;
 uchar code;
 };

struct neg_half_space
 {
 uchar code;
 uchar authenticity_degree;
 };

struct pos_half_space
 {
 uchar code;
 uchar authenticity_degree;
 };

struct sheet_disk_descr
 {
 uchar code;
 char quant_fragm;
 uint16_t sheet_numb;
 uint16_t descr_lth;
 uchar byte_flag;
 uint16_t resolution;
 uint16_t  incline;
 uint16_t version;
 char tabl[11];
 };

struct fragm_disk_descr
 {
 uchar code;
 uint16_t row;                             /* coordinates of left upper  */
 uint16_t col;                             /* angle of fragment's frame  */
 uint16_t height;                          /* height of fragment         */
 uint16_t w_width;                         /* Q.w_width of fragment      */
 char type;
#define FD_TYPE_TEXT 0
#define FD_TYPE_PICT 1
#define FD_TYPE_TABLE 2
#define FD_TYPE_EMPTY 3

 uchar kegl;                           /* kegl for following fragm    */
 uchar font;                            /* font ~~~~~~~~~~~~~~~~~~    */
 uchar language;//reserv;              /* language for fragment       03-29-94 02:21pm,Pit*/
 uchar type_underl;                    /* type specifications of font    */
 };				      /*     for additional information */
				      /*     look at underline          */


typedef struct text_ref	EDREM;

struct letter
{
    uchar    bType;          //  ASCII code.  >= ' '.
    uchar    bAttrib;
};

typedef struct letterEx
{
    uchar    alternative;          //  ASCII code.  >= ' '.
    uchar    probability;
}LETTER;

#define SSR_HUGE		0    /* Internal remark about huge letter */

/* Seria within broken line: first - BROKEN_X, last - BROKEN_W  */
#define SSR_BROKEN_BASELINE	1
#define SSR_BROKEN_HEIGHT	2
#define SSR_BROKEN_X		3
#define SSR_BROKEN_W		4

/* Seria about line: first - LINE_FN, other - optional  */
#define SSR_LINE_FN		5
#define SSR_LINE_PARAGRAPH	6
#define SSR_LINE_TYPE		7
#define SSR_LINE_INDENT		8
#define SSR_LINE_NPIECES        9
#define SSR_LINE_FICT		16
#define SSR_LINE_BULIND		23
#define SSR_LINE_X		24
#define SSR_LINE_W		25
#define SSR_LINE_BASELINE	26
#define SSR_LINE_HEIGHT		27

/* Seria about fragment: first - FRAG_TYPE      */
#define SSR_FRAG_TYPE		10
#define SSR_FRAG_BASE		11
#define SSR_FRAG_X		12
#define SSR_FRAG_W		13
#define SSR_FRAG_N		14
#define SSR_FRAG_SN		17
#define SSR_FRAG_REL		18
#define SSR_FRAG_Y   		19
#define SSR_FRAG_H		20
#define SSR_FRAG_PNUM		21
#define SSR_FRAG_COLXW		28

#define SSR_FRAG_END		15	/* end of fragments list  */

/* Misceleneaus  */

#define SSR_LINE_NUMBER		22	/* Internal line number  */
#define SSR_WORD_BOLD           32      /* density of word */
#define SSR_SHEET_TYPE          33      /* type of sheet */

//#define	SSR_SECT_BORD_TOP		34
//#define	SSR_SECT_BORD_BOTTOM	35
//#define	SSR_SECT_BORD_LEFT		36
//#define	SSR_SECT_BORD_RIGHT		37

#define	SSR_COL_WIDTH			38
#define	SSR_COL_SPACING			39

#define SSR_FRAME_X				40
#define SSR_FRAME_Y				41
#define SSR_FRAME_W				42
#define SSR_FRAME_H				43

//Fragment types
#define TP_ONE_LINE      0x0001
#define TP_LEFT_ALLIGN   0x0002
#define TP_RIGHT_ALLIGN  0x0004
#define TP_CENTER        0x0008
#define TP_POS_INDENT    0x0010
#define TP_NEG_INDENT    0x0020
#define TP_BULLET        0x0040
#define TP_POESY         0x0080
#define TP_LN_SPACE      0x0100
#define TP_NOT_RECOG     0x0200
#define TP_BORDER        0x0400
#define TP_BRACKET       0x8000
#define TP_MCOL_BEG      (TP_BRACKET|0x1000)
#define TP_NEW_COL       (TP_BRACKET|0x2000)
#define TP_MCOL_END      (TP_BRACKET|0x3000)
#define TP_TAB_BEG       (TP_BRACKET|0x4000)
#define TP_NEW_ROW       (TP_BRACKET|0x5000)
#define TP_FRAME_BEG      (TP_BRACKET|0x6000)
#define TP_FRAME_END      (TP_BRACKET|0x7000)
#define TP_NEW_TAB_BEG	 (TP_BRACKET|0x4100)
#define TP_NEW_ROW_BEG   (TP_BRACKET|0x5100)
#define TP_NEW_CELL_BEG  (TP_BRACKET|0x2100)
#define TP_NEW_TAB_END   (TP_BRACKET|0x3100)
#define TP_DEL           (TP_NOT_RECOG|TP_BORDER)
#define TP_FICT_FR_FLAGS (TP_BORDER|TP_BRACKET)


#pragma pack(pop)

#include "edext.h"
#endif