annotate src/spell.c @ 300:86cd0a77d2ae

updated for version 7.0079
author vimboss
date Sat, 04 Jun 2005 21:55:20 +0000
parents 7700c64256a8
children 250611b3068d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
223
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
1 /* vi:set ts=8 sts=4 sw=4:
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
2 *
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
3 * VIM - Vi IMproved by Bram Moolenaar
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
4 *
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
5 * Do ":help uganda" in Vim to read copying and usage conditions.
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
6 * Do ":help credits" in Vim to see a list of people who contributed.
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
7 * See README.txt for an overview of the Vim source code.
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
8 */
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
9
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
10 /*
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
11 * spell.c: code for spell checking
226
4e7dca477fee updated for version 7.0063
vimboss
parents: 223
diff changeset
12 *
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
13 * The spell checking mechanism uses a tree (aka trie). Each node in the tree
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
14 * has a list of bytes that can appear (siblings). For each byte there is a
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
15 * pointer to the node with the byte that follows in the word (child).
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
16 * A NUL byte is used where the word may end.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
17 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
18 * There are two trees: one with case-folded words and one with words in
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
19 * original case. The second one is only used for keep-case words and is
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
20 * usually small.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
21 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
22 * Thanks to Olaf Seibert for providing an example implementation of this tree
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
23 * and the compression mechanism.
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
24 *
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
25 * Matching involves checking the caps type: Onecap ALLCAP KeepCap.
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
26 *
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
27 * Why doesn't Vim use aspell/ispell/myspell/etc.?
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
28 * See ":help develop-spell".
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
29 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
30
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
31 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
32 * Vim spell file format: <HEADER> <SUGGEST> <LWORDTREE> <KWORDTREE>
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
33 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
34 * <HEADER>: <fileID> <regioncnt> <regionname> ...
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
35 * <charflagslen> <charflags> <fcharslen> <fchars>
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
36 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
37 * <fileID> 10 bytes "VIMspell05"
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
38 * <regioncnt> 1 byte number of regions following (8 supported)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
39 * <regionname> 2 bytes Region name: ca, au, etc.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
40 * First <regionname> is region 1.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
41 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
42 * <charflagslen> 1 byte Number of bytes in <charflags> (should be 128).
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
43 * <charflags> N bytes List of flags (first one is for character 128):
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
44 * 0x01 word character
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
45 * 0x01 upper-case character
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
46 * <fcharslen> 2 bytes Number of bytes in <fchars>.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
47 * <fchars> N bytes Folded characters, first one is for character 128.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
48 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
49 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
50 * <SUGGEST> : <suggestlen> <more> ...
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
51 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
52 * <suggestlen> 4 bytes Length of <SUGGEST> in bytes, excluding
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
53 * <suggestlen>. MSB first.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
54 * <more> To be defined.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
55 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
56 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
57 * <LWORDTREE>: <wordtree>
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
58 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
59 * <wordtree>: <nodecount> <nodedata> ...
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
60 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
61 * <nodecount> 4 bytes Number of nodes following. MSB first.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
62 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
63 * <nodedata>: <siblingcount> <sibling> ...
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
64 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
65 * <siblingcount> 1 byte Number of siblings in this node. The siblings
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
66 * follow in sorted order.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
67 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
68 * <sibling>: <byte> [<nodeidx> <xbyte> | <flags> [<region>]]
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
69 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
70 * <byte> 1 byte Byte value of the sibling. Special cases:
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
71 * BY_NOFLAGS: End of word without flags and for all
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
72 * regions.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
73 * BY_FLAGS: End of word, <flags> follow.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
74 * BY_INDEX: Child of sibling is shared, <nodeidx>
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
75 * and <xbyte> follow.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
76 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
77 * <nodeidx> 3 bytes Index of child for this sibling, MSB first.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
78 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
79 * <xbyte> 1 byte byte value of the sibling.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
80 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
81 * <flags> 1 byte bitmask of:
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
82 * WF_ALLCAP word must have only capitals
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
83 * WF_ONECAP first char of word must be capital
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
84 * WF_RARE rare word
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
85 * WF_REGION <region> follows
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
86 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
87 * <region> 1 byte Bitmask for regions in which word is valid. When
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
88 * omitted it's valid in all regions.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
89 * Lowest bit is for region 1.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
90 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
91 * <KWORDTREE>: <wordtree>
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
92 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
93 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
94 * All text characters are in 'encoding', but stored as single bytes.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
95 * The region name is ASCII.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
96 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
97
223
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
98 #if defined(MSDOS) || defined(WIN16) || defined(WIN32) || defined(_WIN64)
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
99 # include <io.h> /* for lseek(), must be before vim.h */
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
100 #endif
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
101
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
102 #include "vim.h"
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
103
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
104 #if defined(FEAT_SYN_HL) || defined(PROTO)
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
105
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
106 #ifdef HAVE_FCNTL_H
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
107 # include <fcntl.h>
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
108 #endif
5175af353b81 updated for version 7.0062
vimboss
parents:
diff changeset
109
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
110 #define MAXWLEN 250 /* assume max. word len is this many bytes */
226
4e7dca477fee updated for version 7.0063
vimboss
parents: 223
diff changeset
111
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
112 /* Flags used for a word. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
113 #define WF_REGION 0x01 /* region byte follows */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
114 #define WF_ONECAP 0x02 /* word with one capital (or all capitals) */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
115 #define WF_ALLCAP 0x04 /* word must be all capitals */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
116 #define WF_RARE 0x08 /* rare word */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
117
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
118 #define WF_KEEPCAP 0x100 /* keep-case word */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
119
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
120 #define BY_NOFLAGS 0 /* end of word without flags or region */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
121 #define BY_FLAGS 1 /* end of word, flag byte follows */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
122 #define BY_INDEX 2 /* child is shared, index follows */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
123 #define BY_SPECIAL BY_INDEX /* hightest special byte value */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
124
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
125 /* Info from "REP" entries in ".aff" file used in af_rep.
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
126 * TODO: This is not used yet. Either use it or remove it. */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
127 typedef struct repentry_S
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
128 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
129 char_u *re_from;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
130 char_u *re_to;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
131 } repentry_T;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
132
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
133 /*
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
134 * Structure used to store words and other info for one language, loaded from
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
135 * a .spl file.
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
136 * The main access is through the tree in "sl_fbyts/sl_fidxs", storing the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
137 * case-folded words. "sl_kbyts/sl_kidxs" is for keep-case words.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
138 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
139 * The "byts" array stores the possible bytes in each tree node, preceded by
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
140 * the number of possible bytes, sorted on byte value:
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
141 * <len> <byte1> <byte2> ...
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
142 * The "idxs" array stores the index of the child node corresponding to the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
143 * byte in "byts".
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
144 * Exception: when the byte is zero, the word may end here and "idxs" holds
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
145 * the flags and region for the word. There may be several zeros in sequence
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
146 * for alternative flag/region combinations.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
147 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
148 typedef struct slang_S slang_T;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
149 struct slang_S
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
150 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
151 slang_T *sl_next; /* next language */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
152 char_u *sl_name; /* language name "en", "en.rare", "nl", etc. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
153 char_u *sl_fbyts; /* case-folded word bytes */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
154 int *sl_fidxs; /* case-folded word indexes */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
155 char_u *sl_kbyts; /* keep-case word bytes */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
156 int *sl_kidxs; /* keep-case word indexes */
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
157 char_u *sl_try; /* "TRY" from .aff file TODO: not used */
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
158 garray_T sl_rep; /* list of repentry_T entries from REP lines
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
159 * TODO not used */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
160 char_u sl_regions[17]; /* table with up to 8 region names plus NUL */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
161 int sl_error; /* error while loading */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
162 };
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
163
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
164 /* First language that is loaded, start of the linked list of loaded
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
165 * languages. */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
166 static slang_T *first_lang = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
167
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
168 #define REGION_ALL 0xff
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
169
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
170
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
171 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
172 * Structure used in "b_langp", filled from 'spelllang'.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
173 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
174 typedef struct langp_S
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
175 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
176 slang_T *lp_slang; /* info for this language (NULL for last one) */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
177 int lp_region; /* bitmask for region or REGION_ALL */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
178 } langp_T;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
179
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
180 #define LANGP_ENTRY(ga, i) (((langp_T *)(ga).ga_data) + (i))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
181
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
182 #define SP_OK 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
183 #define SP_BAD 1
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
184 #define SP_RARE 2
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
185 #define SP_LOCAL 3
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
186
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
187 #define VIMSPELLMAGIC "VIMspell05" /* string at start of Vim spell file */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
188 #define VIMSPELLMAGICL 10
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
189
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
190 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
191 * Structure to store info for word matching.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
192 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
193 typedef struct matchinf_S
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
194 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
195 langp_T *mi_lp; /* info for language and region */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
196 slang_T *mi_slang; /* info for the language */
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
197
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
198 /* pointers to original text to be checked */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
199 char_u *mi_word; /* start of word being checked */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
200 char_u *mi_end; /* end of matching word */
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
201 char_u *mi_fend; /* next char to be added to mi_fword */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
202 char_u *mi_cend; /* char after what was used for
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
203 mi_capflags */
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
204
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
205 /* case-folded text */
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
206 char_u mi_fword[MAXWLEN + 1]; /* mi_word case-folded */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
207 int mi_fwordlen; /* nr of valid bytes in mi_fword */
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
208
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
209 /* others */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
210 int mi_result; /* result so far: SP_BAD, SP_OK, etc. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
211 int mi_capflags; /* WF_ONECAP WF_ALLCAP WF_KEEPCAP */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
212 } matchinf_T;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
213
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
214 static slang_T *slang_alloc __ARGS((char_u *lang));
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
215 static void slang_free __ARGS((slang_T *lp));
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
216 static void find_word __ARGS((matchinf_T *mip, int keepcap));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
217 static slang_T *spell_load_lang __ARGS((char_u *lang));
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
218 static void spell_load_file __ARGS((char_u *fname, void *cookie));
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
219 static int read_tree __ARGS((FILE *fd, char_u *byts, int *idxs, int maxidx, int startidx));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
220 static int find_region __ARGS((char_u *rp, char_u *region));
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
221 static int captype __ARGS((char_u *word, char_u *end));
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
222
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
223 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
224 * Main spell-checking function.
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
225 * "ptr" points to a character that could be the start of a word.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
226 * "*attrp" is set to the attributes for a badly spelled word. For a non-word
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
227 * or when it's OK it remains unchanged.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
228 * This must only be called when 'spelllang' is not empty.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
229 * Returns the length of the word in bytes, also when it's OK, so that the
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
230 * caller can skip over the word.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
231 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
232 int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
233 spell_check(wp, ptr, attrp)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
234 win_T *wp; /* current window */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
235 char_u *ptr;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
236 int *attrp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
237 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
238 matchinf_T mi; /* Most things are put in "mi" so that it can
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
239 be passed to functions quickly. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
240
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
241 /* Find the end of the word. */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
242 mi.mi_word = ptr;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
243 mi.mi_end = ptr;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
244
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
245 /* A word starting with a number is always OK. Also skip hexadecimal
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
246 * numbers 0xFF99 and 0X99FF. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
247 if (*ptr >= '0' && *ptr <= '9')
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
248 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
249 if (*ptr == '0' && (ptr[1] == 'x' || ptr[2] == 'X'))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
250 mi.mi_end = skiphex(ptr);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
251 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
252 mi.mi_end = skipdigits(ptr);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
253 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
254 else
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
255 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
256 mi.mi_fend = ptr;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
257 if (spell_iswordc(mi.mi_fend))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
258 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
259 /* Make case-folded copy of the characters until the next non-word
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
260 * character. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
261 do
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
262 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
263 mb_ptr_adv(mi.mi_fend);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
264 } while (*mi.mi_fend != NUL && spell_iswordc(mi.mi_fend));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
265
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
266 (void)spell_casefold(ptr, (int)(mi.mi_fend - ptr), mi.mi_fword,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
267 MAXWLEN + 1);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
268 mi.mi_fwordlen = STRLEN(mi.mi_fword);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
269
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
270 /* Check the caps type of the word. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
271 mi.mi_capflags = captype(ptr, mi.mi_fend);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
272
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
273 /* We always use the characters up to the next non-word character,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
274 * also for bad words. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
275 mi.mi_end = mi.mi_fend;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
276 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
277 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
278 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
279 /* No word characters. Don't case-fold anything, we may quickly
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
280 * find out this is not a word (but it could be!). */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
281 mi.mi_fwordlen = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
282 mi.mi_capflags = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
283 }
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
284
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
285 mi.mi_cend = mi.mi_fend;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
286
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
287 /* The word is bad unless we recognize it. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
288 mi.mi_result = SP_BAD;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
289
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
290 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
291 * Loop over the languages specified in 'spelllang'.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
292 * We check them all, because a matching word may be longer than an
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
293 * already found matching word.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
294 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
295 for (mi.mi_lp = LANGP_ENTRY(wp->w_buffer->b_langp, 0);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
296 mi.mi_lp->lp_slang != NULL; ++mi.mi_lp)
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
297 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
298 /* Check for a matching word in case-folded words. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
299 find_word(&mi, FALSE);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
301 /* Try keep-case words. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
302 find_word(&mi, TRUE);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
303 }
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
304
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
305 if (mi.mi_result != SP_OK)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
306 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
307 /* When we are at a non-word character there is no error, just
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
308 * skip over the character (try looking for a word after it). */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
309 if (!spell_iswordc(ptr))
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
310 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
311 #ifdef FEAT_MBYTE
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
312 if (has_mbyte)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
313 return mb_ptr2len_check(ptr);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
314 #endif
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
315 return 1;
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
316 }
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
317
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
318 if (mi.mi_result == SP_BAD)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
319 *attrp = highlight_attr[HLF_SPB];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
320 else if (mi.mi_result == SP_RARE)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
321 *attrp = highlight_attr[HLF_SPR];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
322 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
323 *attrp = highlight_attr[HLF_SPL];
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
324 }
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
325 }
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
326
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
327 return (int)(mi.mi_end - ptr);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
328 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
329
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
330 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
331 * Check if the word at "mip->mi_word" is in the tree.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
332 * When "keepcap" is TRUE check in keep-case word tree.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
333 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
334 * For a match mip->mi_result is updated.
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
335 */
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
336 static void
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
337 find_word(mip, keepcap)
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
338 matchinf_T *mip;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
339 int keepcap;
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
340 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
341 int arridx = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
342 int endlen[MAXWLEN]; /* length at possible word endings */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
343 int endidx[MAXWLEN]; /* possible word endings */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
344 int endidxcnt = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
345 int len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
346 int wlen = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
347 int flen;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
348 int c;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
349 char_u *ptr;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
350 unsigned lo, hi, m;
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
351 #ifdef FEAT_MBYTE
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
352 char_u *s;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
353 char_u *p;
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
354 #endif
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
355 int res;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
356 int valid;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
357 slang_T *slang = mip->mi_lp->lp_slang;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
358 unsigned flags;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
359 char_u *byts;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
360 int *idxs;
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
361
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
362 if (keepcap)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
363 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
364 /* Check for word with matching case in keep-case tree. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
365 ptr = mip->mi_word;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
366 flen = 9999; /* no case folding, always enough bytes */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
367 byts = slang->sl_kbyts;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
368 idxs = slang->sl_kidxs;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
369 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
370 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
371 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
372 /* Check for case-folded in case-folded tree. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
373 ptr = mip->mi_fword;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
374 flen = mip->mi_fwordlen; /* available case-folded bytes */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
375 byts = slang->sl_fbyts;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
376 idxs = slang->sl_fidxs;
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
377 }
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
378
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
379 if (byts == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
380 return; /* array is empty */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
381
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
382 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
383 * Repeat advancing in the tree until there is a byte that doesn't match,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
384 * we reach the end of the tree or we reach the end of the line.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
385 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
386 for (;;)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
387 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
388 if (flen == 0 && *mip->mi_fend != NUL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
389 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
390 /* Need to fold at least one more character. Do until next
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
391 * non-word character for efficiency. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
392 do
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
393 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
394 #ifdef FEAT_MBYTE
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
395 if (has_mbyte)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
396 flen += mb_ptr2len_check(mip->mi_fend + flen);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
397 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
398 #endif
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
399 ++flen;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
400 } while (spell_iswordc(mip->mi_fend + flen));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
401
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
402 (void)spell_casefold(mip->mi_fend, flen,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
403 mip->mi_fword + mip->mi_fwordlen,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
404 MAXWLEN - mip->mi_fwordlen);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
405 mip->mi_fend += flen;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
406 flen = STRLEN(mip->mi_fword + mip->mi_fwordlen);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
407 mip->mi_fwordlen += flen;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
408 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
409
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
410 len = byts[arridx++];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
411
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
412 /* If the first possible byte is a zero the word could end here.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
413 * Remember this index, we first check for the longest word. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
414 if (byts[arridx] == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
415 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
416 endlen[endidxcnt] = wlen;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
417 endidx[endidxcnt++] = arridx++;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
418 --len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
419
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
420 /* Skip over the zeros, there can be several flag/region
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
421 * combinations. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
422 while (len > 0 && byts[arridx] == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
423 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
424 ++arridx;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
425 --len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
426 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
427 if (len == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
428 break; /* no children, word must end here */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
429 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
430
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
431 /* Stop looking at end of the line. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
432 if (ptr[wlen] == NUL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
433 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
434
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
435 /* Perform a binary search in the list of accepted bytes. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
436 c = ptr[wlen];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
437 lo = arridx;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
438 hi = arridx + len - 1;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
439 while (lo < hi)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
440 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
441 m = (lo + hi) / 2;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
442 if (byts[m] > c)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
443 hi = m - 1;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
444 else if (byts[m] < c)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
445 lo = m + 1;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
446 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
447 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
448 lo = hi = m;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
449 break;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
450 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
451 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
452
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
453 /* Stop if there is no matching byte. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
454 if (hi < lo || byts[lo] != c)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
455 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
456
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
457 /* Continue at the child (if there is one). */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
458 arridx = idxs[lo];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
459 ++wlen;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
460 --flen;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
461 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
462
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
463 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
464 * Verify that one of the possible endings is valid. Try the longest
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
465 * first.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
466 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
467 while (endidxcnt > 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
468 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
469 --endidxcnt;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
470 arridx = endidx[endidxcnt];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
471 wlen = endlen[endidxcnt];
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
472
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
473 #ifdef FEAT_MBYTE
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
474 if ((*mb_head_off)(ptr, ptr + wlen) > 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
475 continue; /* not at first byte of character */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
476 #endif
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
477 if (spell_iswordc(ptr + wlen))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
478 continue; /* next char is a word character */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
479
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
480 #ifdef FEAT_MBYTE
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
481 if (!keepcap && has_mbyte)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
482 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
483 /* Compute byte length in original word, length may change
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
484 * when folding case. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
485 p = mip->mi_word;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
486 for (s = ptr; s < ptr + wlen; mb_ptr_adv(s))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
487 mb_ptr_adv(p);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
488 wlen = p - mip->mi_word;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
489 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
490 #endif
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
491
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
492 /* Check flags and region. Repeat this if there are more
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
493 * flags/region alternatives until there is a match. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
494 res = SP_BAD;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
495 for (len = byts[arridx - 1]; len > 0 && byts[arridx] == 0; --len)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
496 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
497 flags = idxs[arridx];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
498 if (keepcap)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
499 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
500 /* For "keepcap" tree the case is always right. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
501 valid = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
502 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
503 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
504 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
505 /* Check that the word is in the required case. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
506 if (mip->mi_cend != mip->mi_word + wlen)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
507 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
508 /* mi_capflags was set for a different word
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
509 * length, need to do it again. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
510 mip->mi_cend = mip->mi_word + wlen;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
511 mip->mi_capflags = captype(mip->mi_word,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
512 mip->mi_cend);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
513 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
514
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
515 valid = (mip->mi_capflags == WF_ALLCAP
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
516 || ((flags & WF_ALLCAP) == 0
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
517 && ((flags & WF_ONECAP) == 0
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
518 || mip->mi_capflags == WF_ONECAP)));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
519 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
520
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
521 if (valid && res != SP_OK)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
522 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
523 if (flags & WF_REGION)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
524 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
525 /* Check region. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
526 if ((mip->mi_lp->lp_region & (flags >> 8)) != 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
527 res = SP_OK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
528 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
529 res = SP_LOCAL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
530 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
531 else if (flags & WF_RARE)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
532 res = SP_RARE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
533 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
534 res = SP_OK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
535 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
536
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
537 if (res == SP_OK)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
538 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
539 ++arridx;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
540 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
541
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
542 if (valid)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
543 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
544 /* Valid word! Always use the longest match. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
545 if (mip->mi_end < mip->mi_word + wlen)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
546 mip->mi_end = mip->mi_word + wlen;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
547 if (mip->mi_result != SP_OK)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
548 mip->mi_result = res;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
549 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
550 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
551 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
552 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
553
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
554
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
555 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
556 * Move to next spell error.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
557 * Return OK if found, FAIL otherwise.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
558 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
559 int
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
560 spell_move_to(dir, allwords)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
561 int dir; /* FORWARD or BACKWARD */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
562 int allwords; /* TRUE for "[s" and "]s" */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
563 {
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
564 linenr_T lnum;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
565 pos_T found_pos;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
566 char_u *line;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
567 char_u *p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
568 int attr = 0;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
569 int len;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
570 int has_syntax = syntax_present(curbuf);
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
571 int col;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
572 int can_spell;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
573
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
574 if (!curwin->w_p_spell || *curwin->w_buffer->b_p_spl == NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
575 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
576 EMSG(_("E756: Spell checking not enabled"));
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
577 return FAIL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
578 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
579
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
580 /*
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
581 * Start looking for bad word at the start of the line, because we can't
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
582 * start halfway a word, we don't know where it starts or ends.
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
583 *
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
584 * When searching backwards, we continue in the line to find the last
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
585 * bad word (in the cursor line: before the cursor).
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
586 */
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
587 lnum = curwin->w_cursor.lnum;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
588 found_pos.lnum = 0;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
589
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
590 while (!got_int)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
591 {
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
592 line = ml_get(lnum);
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
593 p = line;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
594
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
595 while (*p != NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
596 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
597 /* When searching backward don't search after the cursor. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
598 if (dir == BACKWARD
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
599 && lnum == curwin->w_cursor.lnum
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
600 && (colnr_T)(p - line) >= curwin->w_cursor.col)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
601 break;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
602
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
603 /* start of word */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
604 len = spell_check(curwin, p, &attr);
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
605
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
606 if (attr != 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
607 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
608 /* We found a bad word. Check the attribute. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
609 /* TODO: check for syntax @Spell cluster. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
610 if (allwords || attr == highlight_attr[HLF_SPB])
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
611 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
612 /* When searching forward only accept a bad word after
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
613 * the cursor. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
614 if (dir == BACKWARD
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
615 || lnum > curwin->w_cursor.lnum
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
616 || (lnum == curwin->w_cursor.lnum
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
617 && (colnr_T)(p - line)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
618 > curwin->w_cursor.col))
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
619 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
620 if (has_syntax)
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
621 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
622 col = p - line;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
623 (void)syn_get_id(lnum, (colnr_T)col,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
624 FALSE, &can_spell);
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
625
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
626 /* have to get the line again, a multi-line
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
627 * regexp may make it invalid */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
628 line = ml_get(lnum);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
629 p = line + col;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
630 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
631 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
632 can_spell = TRUE;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
633
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
634 if (can_spell)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
635 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
636 found_pos.lnum = lnum;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
637 found_pos.col = p - line;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
638 #ifdef FEAT_VIRTUALEDIT
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
639 found_pos.coladd = 0;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
640 #endif
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
641 if (dir == FORWARD)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
642 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
643 /* No need to search further. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
644 curwin->w_cursor = found_pos;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
645 return OK;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
646 }
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
647 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
648 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
649 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
650 attr = 0;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
651 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
652
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
653 /* advance to character after the word */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
654 p += len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
655 if (*p == NUL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
656 break;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
657 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
658
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
659 /* Advance to next line. */
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
660 if (dir == BACKWARD)
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
661 {
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
662 if (found_pos.lnum != 0)
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
663 {
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
664 /* Use the last match in the line. */
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
665 curwin->w_cursor = found_pos;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
666 return OK;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
667 }
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
668 if (lnum == 1)
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
669 return FAIL;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
670 --lnum;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
671 }
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
672 else
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
673 {
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
674 if (lnum == curbuf->b_ml.ml_line_count)
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
675 return FAIL;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
676 ++lnum;
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
677 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
678
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
679 line_breakcheck();
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
680 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
681
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
682 return FAIL; /* interrupted */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
683 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
684
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
685 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
686 * Load word list for "lang" from a Vim spell file.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
687 * "lang" must be the language without the region: "en" or "en-rare".
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
688 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
689 static slang_T *
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
690 spell_load_lang(lang)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
691 char_u *lang;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
692 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
693 slang_T *lp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
694 char_u fname_enc[80];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
695 char_u *p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
696 int r;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
697
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
698 lp = slang_alloc(lang);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
699 if (lp != NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
700 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
701 /* Find all spell files for "lang" in 'runtimepath' and load them.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
702 * Use 'encoding', except that we use "latin1" for "latin9". */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
703 #ifdef FEAT_MBYTE
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
704 if (STRLEN(p_enc) < 60 && STRCMP(p_enc, "iso-8859-15") != 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
705 p = p_enc;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
706 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
707 #endif
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
708 p = (char_u *)"latin1";
272
ddada568db54 updated for version 7.0073
vimboss
parents: 260
diff changeset
709 vim_snprintf((char *)fname_enc, sizeof(fname_enc),
ddada568db54 updated for version 7.0073
vimboss
parents: 260
diff changeset
710 "spell/%s.%s.spl", lang, p);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
711
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
712 r = do_in_runtimepath(fname_enc, TRUE, spell_load_file, lp);
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
713 if (r == FAIL && !lp->sl_error)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
714 {
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
715 /* Try loading the ASCII version. */
272
ddada568db54 updated for version 7.0073
vimboss
parents: 260
diff changeset
716 vim_snprintf((char *)fname_enc, sizeof(fname_enc),
ddada568db54 updated for version 7.0073
vimboss
parents: 260
diff changeset
717 "spell/%s.ascii.spl", lang);
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
718
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
719 r = do_in_runtimepath(fname_enc, TRUE, spell_load_file, lp);
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
720 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
721 if (r == FAIL || lp->sl_error)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
722 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
723 slang_free(lp);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
724 lp = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
725 if (r == FAIL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
726 smsg((char_u *)_("Warning: Cannot find word list \"%s\""),
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
727 fname_enc + 6);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
728 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
729 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
730 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
731 lp->sl_next = first_lang;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
732 first_lang = lp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
733 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
734 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
735
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
736 return lp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
737 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
738
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
739 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
740 * Allocate a new slang_T.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
741 * Caller must fill "sl_next".
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
742 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
743 static slang_T *
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
744 slang_alloc(lang)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
745 char_u *lang;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
746 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
747 slang_T *lp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
748
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
749 lp = (slang_T *)alloc_clear(sizeof(slang_T));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
750 if (lp != NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
751 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
752 lp->sl_name = vim_strsave(lang);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
753 ga_init2(&lp->sl_rep, sizeof(repentry_T), 4);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
754 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
755 return lp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
756 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
757
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
758 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
759 * Free the contents of an slang_T and the structure itself.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
760 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
761 static void
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
762 slang_free(lp)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
763 slang_T *lp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
764 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
765 vim_free(lp->sl_name);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
766 vim_free(lp->sl_fbyts);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
767 vim_free(lp->sl_kbyts);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
768 vim_free(lp->sl_fidxs);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
769 vim_free(lp->sl_kidxs);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
770 ga_clear(&lp->sl_rep);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
771 vim_free(lp->sl_try);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
772 vim_free(lp);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
773 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
774
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
775 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
776 * Load one spell file into an slang_T.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
777 * Invoked through do_in_runtimepath().
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
778 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
779 static void
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
780 spell_load_file(fname, cookie)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
781 char_u *fname;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
782 void *cookie; /* points to the slang_T to be filled */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
783 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
784 slang_T *lp = cookie;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
785 FILE *fd;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
786 char_u buf[MAXWLEN + 1];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
787 char_u *p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
788 int i;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
789 int len;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
790 int round;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
791 char_u *save_sourcing_name = sourcing_name;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
792 linenr_T save_sourcing_lnum = sourcing_lnum;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
793 int cnt, ccnt;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
794 char_u *fol;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
795
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
796 fd = fopen((char *)fname, "r");
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
797 if (fd == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
798 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
799 EMSG2(_(e_notopen), fname);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
800 goto endFAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
801 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
802
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
803 /* Set sourcing_name, so that error messages mention the file name. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
804 sourcing_name = fname;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
805 sourcing_lnum = 0;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
806
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
807 /* <HEADER>: <fileID> <regioncnt> <regionname> ...
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
808 * <charflagslen> <charflags> <fcharslen> <fchars> */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
809 for (i = 0; i < VIMSPELLMAGICL; ++i)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
810 buf[i] = getc(fd); /* <fileID> */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
811 if (STRNCMP(buf, VIMSPELLMAGIC, VIMSPELLMAGICL) != 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
812 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
813 EMSG(_("E757: Wrong file ID in spell file"));
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
814 goto endFAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
815 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
816
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
817 cnt = getc(fd); /* <regioncnt> */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
818 if (cnt < 0)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
819 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
820 truncerr:
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
821 EMSG(_("E758: Truncated spell file"));
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
822 goto endFAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
823 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
824 if (cnt > 8)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
825 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
826 formerr:
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
827 EMSG(_("E759: Format error in spell file"));
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
828 goto endFAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
829 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
830 for (i = 0; i < cnt; ++i)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
831 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
832 lp->sl_regions[i * 2] = getc(fd); /* <regionname> */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
833 lp->sl_regions[i * 2 + 1] = getc(fd);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
834 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
835 lp->sl_regions[cnt * 2] = NUL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
836
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
837 cnt = getc(fd); /* <charflagslen> */
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
838 if (cnt > 0)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
839 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
840 p = alloc((unsigned)cnt);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
841 if (p == NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
842 goto endFAIL;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
843 for (i = 0; i < cnt; ++i)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
844 p[i] = getc(fd); /* <charflags> */
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
845
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
846 ccnt = (getc(fd) << 8) + getc(fd); /* <fcharslen> */
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
847 if (ccnt <= 0)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
848 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
849 vim_free(p);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
850 goto formerr;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
851 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
852 fol = alloc((unsigned)ccnt + 1);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
853 if (fol == NULL)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
854 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
855 vim_free(p);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
856 goto endFAIL;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
857 }
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
858 for (i = 0; i < ccnt; ++i)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
859 fol[i] = getc(fd); /* <fchars> */
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
860 fol[i] = NUL;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
861
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
862 /* Set the word-char flags and fill spell_isupper() table. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
863 i = set_spell_charflags(p, cnt, fol);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
864 vim_free(p);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
865 vim_free(fol);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
866 if (i == FAIL)
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
867 goto formerr;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
868 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
869 else
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
870 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
871 /* When <charflagslen> is zero then <fcharlen> must also be zero. */
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
872 cnt = (getc(fd) << 8) + getc(fd);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
873 if (cnt != 0)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
874 goto formerr;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
875 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
876
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
877 /* <SUGGEST> : <suggestlen> <more> ... */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
878 /* TODO, just skip this for now */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
879 i = (getc(fd) << 24) + (getc(fd) << 16) + (getc(fd) << 8) + getc(fd);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
880 while (i-- > 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
881 if (getc(fd) == EOF) /* <suggestlen> */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
882 goto truncerr;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
883
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
884 /* round 1: <LWORDTREE>
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
885 * round 2: <KWORDTREE> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
886 for (round = 1; round <= 2; ++round)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
887 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
888 /* The tree size was computed when writing the file, so that we can
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
889 * allocate it as one long block. <nodecount> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
890 len = (getc(fd) << 24) + (getc(fd) << 16) + (getc(fd) << 8) + getc(fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
891 if (len < 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
892 goto truncerr;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
893 if (len > 0)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
894 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
895 /* Allocate the byte array. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
896 p = lalloc((long_u)len, TRUE);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
897 if (p == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
898 goto endFAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
899 if (round == 1)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
900 lp->sl_fbyts = p;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
901 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
902 lp->sl_kbyts = p;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
903
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
904 /* Allocate the index array. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
905 p = lalloc_clear((long_u)(len * sizeof(int)), TRUE);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
906 if (p == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
907 goto endFAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
908 if (round == 1)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
909 lp->sl_fidxs = (int *)p;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
910 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
911 lp->sl_kidxs = (int *)p;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
912
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
913
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
914 /* Read the tree and store it in the array. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
915 i = read_tree(fd,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
916 round == 1 ? lp->sl_fbyts : lp->sl_kbyts,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
917 round == 1 ? lp->sl_fidxs : lp->sl_kidxs,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
918 len, 0);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
919 if (i == -1)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
920 goto truncerr;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
921 if (i < 0)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
922 goto formerr;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
923 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
924 }
243
8ff168d3720a updated for version 7.0068
vimboss
parents: 240
diff changeset
925
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
926 goto endOK;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
927
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
928 endFAIL:
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
929 lp->sl_error = TRUE;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
930
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
931 endOK:
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
932 if (fd != NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
933 fclose(fd);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
934 sourcing_name = save_sourcing_name;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
935 sourcing_lnum = save_sourcing_lnum;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
936 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
937
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
938 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
939 * Read one row of siblings from the spell file and store it in the byte array
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
940 * "byts" and index array "idxs". Recursively read the children.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
941 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
942 * NOTE: The code here must match put_tree().
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
943 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
944 * Returns the index follosing the siblings.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
945 * Returns -1 if the file is shorter than expected.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
946 * Returns -2 if there is a format error.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
947 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
948 static int
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
949 read_tree(fd, byts, idxs, maxidx, startidx)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
950 FILE *fd;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
951 char_u *byts;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
952 int *idxs;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
953 int maxidx; /* size of arrays */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
954 int startidx; /* current index in "byts" and "idxs" */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
955 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
956 int len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
957 int i;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
958 int n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
959 int idx = startidx;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
960 int c;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
961 #define SHARED_MASK 0x8000000
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
962
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
963 len = getc(fd); /* <siblingcount> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
964 if (len <= 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
965 return -1;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
966
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
967 if (startidx + len >= maxidx)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
968 return -2;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
969 byts[idx++] = len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
970
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
971 /* Read the byte values, flag/region bytes and shared indexes. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
972 for (i = 1; i <= len; ++i)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
973 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
974 c = getc(fd); /* <byte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
975 if (c < 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
976 return -1;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
977 if (c <= BY_SPECIAL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
978 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
979 if (c == BY_NOFLAGS)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
980 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
981 /* No flags, all regions. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
982 idxs[idx] = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
983 c = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
984 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
985 else if (c == BY_FLAGS)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
986 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
987 /* Read flags and option region. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
988 c = getc(fd); /* <flags> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
989 if (c & WF_REGION)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
990 c = (getc(fd) << 8) + c; /* <region> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
991 idxs[idx] = c;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
992 c = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
993 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
994 else /* c == BY_INDEX */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
995 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
996 /* <nodeidx> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
997 n = (getc(fd) << 16) + (getc(fd) << 8) + getc(fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
998 if (n < 0 || n >= maxidx)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
999 return -2;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1000 idxs[idx] = n + SHARED_MASK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1001 c = getc(fd); /* <xbyte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1002 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1003 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1004 byts[idx++] = c;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1005 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1006
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1007 /* Recursively read the children for non-shared siblings.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1008 * Skip the end-of-word ones (zero byte value) and the shared ones (and
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1009 * remove SHARED_MASK) */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1010 for (i = 1; i <= len; ++i)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1011 if (byts[startidx + i] != 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1012 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1013 if (idxs[startidx + i] & SHARED_MASK)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1014 idxs[startidx + i] &= ~SHARED_MASK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1015 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1016 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1017 idxs[startidx + i] = idx;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1018 idx = read_tree(fd, byts, idxs, maxidx, idx);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1019 if (idx < 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1020 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1021 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1022 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1023
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1024 return idx;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1025 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1026
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1027 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1028 * Parse 'spelllang' and set buf->b_langp accordingly.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1029 * Returns an error message or NULL.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1030 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1031 char_u *
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1032 did_set_spelllang(buf)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1033 buf_T *buf;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1034 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1035 garray_T ga;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1036 char_u *lang;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1037 char_u *e;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1038 char_u *region;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1039 int region_mask;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1040 slang_T *lp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1041 int c;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1042 char_u lbuf[MAXWLEN + 1];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1043
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1044 ga_init2(&ga, sizeof(langp_T), 2);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1045
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1046 /* loop over comma separated languages. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1047 for (lang = buf->b_p_spl; *lang != NUL; lang = e)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1048 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1049 e = vim_strchr(lang, ',');
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1050 if (e == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1051 e = lang + STRLEN(lang);
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1052 region = NULL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1053 if (e > lang + 2)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1054 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1055 if (e - lang >= MAXWLEN)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1056 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1057 ga_clear(&ga);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1058 return e_invarg;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1059 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1060 if (lang[2] == '_')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1061 region = lang + 3;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1062 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1063
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1064 for (lp = first_lang; lp != NULL; lp = lp->sl_next)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1065 if (STRNICMP(lp->sl_name, lang, 2) == 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1066 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1067
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1068 if (lp == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1069 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1070 /* Not found, load the language. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1071 STRNCPY(lbuf, lang, e - lang);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1072 lbuf[e - lang] = NUL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1073 if (region != NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1074 mch_memmove(lbuf + 2, lbuf + 5, e - lang - 4);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1075 lp = spell_load_lang(lbuf);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1076 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1077
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1078 if (lp != NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1079 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1080 if (region == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1081 region_mask = REGION_ALL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1082 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1083 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1084 /* find region in sl_regions */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1085 c = find_region(lp->sl_regions, region);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1086 if (c == REGION_ALL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1087 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1088 c = *e;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1089 *e = NUL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1090 smsg((char_u *)_("Warning: region %s not supported"), lang);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1091 *e = c;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1092 region_mask = REGION_ALL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1093 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1094 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1095 region_mask = 1 << c;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1096 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1097
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1098 if (ga_grow(&ga, 1) == FAIL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1099 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1100 ga_clear(&ga);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1101 return e_outofmem;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1102 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1103 LANGP_ENTRY(ga, ga.ga_len)->lp_slang = lp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1104 LANGP_ENTRY(ga, ga.ga_len)->lp_region = region_mask;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1105 ++ga.ga_len;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1106 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1107
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1108 if (*e == ',')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1109 ++e;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1110 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1111
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1112 /* Add a NULL entry to mark the end of the list. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1113 if (ga_grow(&ga, 1) == FAIL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1114 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1115 ga_clear(&ga);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1116 return e_outofmem;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1117 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1118 LANGP_ENTRY(ga, ga.ga_len)->lp_slang = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1119 ++ga.ga_len;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1120
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1121 /* Everything is fine, store the new b_langp value. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1122 ga_clear(&buf->b_langp);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1123 buf->b_langp = ga;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1124
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1125 return NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1126 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1127
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1128 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1129 * Find the region "region[2]" in "rp" (points to "sl_regions").
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1130 * Each region is simply stored as the two characters of it's name.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1131 * Returns the index if found, REGION_ALL if not found.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1132 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1133 static int
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1134 find_region(rp, region)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1135 char_u *rp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1136 char_u *region;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1137 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1138 int i;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1139
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1140 for (i = 0; ; i += 2)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1141 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1142 if (rp[i] == NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1143 return REGION_ALL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1144 if (rp[i] == region[0] && rp[i + 1] == region[1])
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1145 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1146 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1147 return i / 2;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1148 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1149
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1150 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1151 * Return type of word:
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1152 * w word 0
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1153 * Word WF_ONECAP
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1154 * W WORD WF_ALLCAP
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1155 * WoRd wOrd WF_KEEPCAP
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1156 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1157 static int
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1158 captype(word, end)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1159 char_u *word;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1160 char_u *end;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1161 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1162 char_u *p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1163 int c;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1164 int firstcap;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1165 int allcap;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1166 int past_second = FALSE; /* past second word char */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1167
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1168 /* find first letter */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1169 for (p = word; !spell_iswordc(p); mb_ptr_adv(p))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1170 if (p >= end)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1171 return 0; /* only non-word characters, illegal word */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1172 #ifdef FEAT_MBYTE
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1173 c = mb_ptr2char_adv(&p);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1174 #else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1175 c = *p++;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1176 #endif
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1177 firstcap = allcap = spell_isupper(c);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1178
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1179 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1180 * Need to check all letters to find a word with mixed upper/lower.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1181 * But a word with an upper char only at start is a ONECAP.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1182 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1183 for ( ; p < end; mb_ptr_adv(p))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1184 if (spell_iswordc(p))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1185 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1186 #ifdef FEAT_MBYTE
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1187 c = mb_ptr2char(p);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1188 #else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1189 c = *p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1190 #endif
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1191 if (!spell_isupper(c))
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1192 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1193 /* UUl -> KEEPCAP */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1194 if (past_second && allcap)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1195 return WF_KEEPCAP;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1196 allcap = FALSE;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1197 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1198 else if (!allcap)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1199 /* UlU -> KEEPCAP */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1200 return WF_KEEPCAP;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1201 past_second = TRUE;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1202 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1203
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1204 if (allcap)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1205 return WF_ALLCAP;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1206 if (firstcap)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1207 return WF_ONECAP;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1208 return 0;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1209 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1210
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1211 # if defined(FEAT_MBYTE) || defined(PROTO)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1212 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1213 * Clear all spelling tables and reload them.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1214 * Used after 'encoding' is set.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1215 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1216 void
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1217 spell_reload()
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1218 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1219 buf_T *buf;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1220 slang_T *lp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1221
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1222 /* Initialize the table for spell_iswordc(). */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1223 init_spell_chartab();
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1224
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1225 /* Unload all allocated memory. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1226 while (first_lang != NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1227 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1228 lp = first_lang;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1229 first_lang = lp->sl_next;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1230 slang_free(lp);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1231 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1232
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1233 /* Go through all buffers and handle 'spelllang'. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1234 for (buf = firstbuf; buf != NULL; buf = buf->b_next)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1235 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1236 ga_clear(&buf->b_langp);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1237 if (*buf->b_p_spl != NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1238 did_set_spelllang(buf);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1239 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1240 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1241 # endif
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1242
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1243
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1244 #if defined(FEAT_MBYTE) || defined(PROTO)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1245 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1246 * Functions for ":mkspell".
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1247 * Only possible with the multi-byte feature.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1248 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1249
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1250 #define MAXLINELEN 500 /* Maximum length in bytes of a line in a .aff
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1251 and .dic file. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1252 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1253 * Main structure to store the contents of a ".aff" file.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1254 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1255 typedef struct afffile_S
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1256 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1257 char_u *af_enc; /* "SET", normalized, alloc'ed string or NULL */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1258 char_u *af_try; /* "TRY" line in "af_enc" encoding */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1259 hashtab_T af_pref; /* hashtable for prefixes, affheader_T */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1260 hashtab_T af_suff; /* hashtable for suffixes, affheader_T */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1261 garray_T af_rep; /* list of repentry_T entries from REP lines */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1262 } afffile_T;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1263
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1264 typedef struct affentry_S affentry_T;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1265 /* Affix entry from ".aff" file. Used for prefixes and suffixes. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1266 struct affentry_S
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1267 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1268 affentry_T *ae_next; /* next affix with same name/number */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1269 char_u *ae_chop; /* text to chop off basic word (can be NULL) */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1270 char_u *ae_add; /* text to add to basic word (can be NULL) */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1271 char_u *ae_cond; /* condition (NULL for ".") */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1272 regprog_T *ae_prog; /* regexp program for ae_cond or NULL */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1273 };
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1274
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1275 /* Affix header from ".aff" file. Used for af_pref and af_suff. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1276 typedef struct affheader_S
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1277 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1278 char_u ah_key[2]; /* key for hashtable == name of affix entry */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1279 int ah_combine; /* suffix may combine with prefix */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1280 affentry_T *ah_first; /* first affix entry */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1281 } affheader_T;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1282
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1283 #define HI2AH(hi) ((affheader_T *)(hi)->hi_key)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1284
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1285 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1286 * Structure that is used to store the items in the word tree. This avoids
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1287 * the need to keep track of each allocated thing, it's freed all at once
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1288 * after ":mkspell" is done.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1289 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1290 #define SBLOCKSIZE 16000 /* size of sb_data */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1291 typedef struct sblock_S sblock_T;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1292 struct sblock_S
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1293 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1294 sblock_T *sb_next; /* next block in list */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1295 int sb_used; /* nr of bytes already in use */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1296 char_u sb_data[1]; /* data, actually longer */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1297 };
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1298
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1299 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1300 * A node in the tree.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1301 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1302 typedef struct wordnode_S wordnode_T;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1303 struct wordnode_S
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1304 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1305 char_u wn_hashkey[6]; /* room for the hash key */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1306 wordnode_T *wn_next; /* next node with same hash key */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1307 wordnode_T *wn_child; /* child (next byte in word) */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1308 wordnode_T *wn_sibling; /* next sibling (alternate byte in word,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1309 always sorted) */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1310 wordnode_T *wn_wnode; /* parent node that will write this node */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1311 int wn_index; /* index in written nodes (valid after first
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1312 round) */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1313 char_u wn_byte; /* Byte for this node. NUL for word end */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1314 char_u wn_flags; /* when wn_byte is NUL: WF_ flags */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1315 char_u wn_region; /* when wn_byte is NUL: region mask */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1316 };
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1317
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1318 #define HI2WN(hi) (wordnode_T *)((hi)->hi_key)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1319
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1320 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1321 * Info used while reading the spell files.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1322 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1323 typedef struct spellinfo_S
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
1324 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1325 wordnode_T *si_foldroot; /* tree with case-folded words */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1326 wordnode_T *si_keeproot; /* tree with keep-case words */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1327 sblock_T *si_blocks; /* memory blocks used */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1328 int si_ascii; /* handling only ASCII words */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1329 int si_region; /* region mask */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1330 vimconv_T si_conv; /* for conversion to 'encoding' */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1331 } spellinfo_T;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
1332
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1333 static afffile_T *spell_read_aff __ARGS((char_u *fname, spellinfo_T *spin));
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1334 static int has_non_ascii __ARGS((char_u *s));
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1335 static void spell_free_aff __ARGS((afffile_T *aff));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1336 static int spell_read_dic __ARGS((char_u *fname, spellinfo_T *spin, afffile_T *affile));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1337 static int store_aff_word __ARGS((char_u *word, spellinfo_T *spin, char_u *afflist, hashtab_T *ht, hashtab_T *xht, int comb));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1338 static int spell_read_wordfile __ARGS((char_u *fname, spellinfo_T *spin));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1339 static void *getroom __ARGS((sblock_T **blp, size_t len));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1340 static char_u *getroom_save __ARGS((sblock_T **blp, char_u *s));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1341 static void free_blocks __ARGS((sblock_T *bl));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1342 static wordnode_T *wordtree_alloc __ARGS((sblock_T **blp));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1343 static int store_word __ARGS((char_u *word, spellinfo_T *spin));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1344 static int tree_add_word __ARGS((char_u *word, wordnode_T *tree, int flags, int region, sblock_T **blp));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1345 static void wordtree_compress __ARGS((wordnode_T *root));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1346 static int node_compress __ARGS((wordnode_T *node, hashtab_T *ht, int *tot));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1347 static int node_equal __ARGS((wordnode_T *n1, wordnode_T *n2));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1348 static void write_vim_spell __ARGS((char_u *fname, spellinfo_T *spin, int regcount, char_u *regchars));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1349 static int put_tree __ARGS((FILE *fd, wordnode_T *node, int index, int regionmask));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1350
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1351 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1352 * Read an affix ".aff" file.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1353 * Returns an afffile_T, NULL for failure.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1354 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1355 static afffile_T *
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1356 spell_read_aff(fname, spin)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1357 char_u *fname;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1358 spellinfo_T *spin;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1359 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1360 FILE *fd;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1361 afffile_T *aff;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1362 char_u rline[MAXLINELEN];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1363 char_u *line;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1364 char_u *pc = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1365 char_u *(items[6]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1366 int itemcnt;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1367 char_u *p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1368 int lnum = 0;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1369 affheader_T *cur_aff = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1370 int aff_todo = 0;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1371 hashtab_T *tp;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1372 char_u *low = NULL;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1373 char_u *fol = NULL;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1374 char_u *upp = NULL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1375
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1376 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1377 * Open the file.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1378 */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1379 fd = fopen((char *)fname, "r");
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1380 if (fd == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1381 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1382 EMSG2(_(e_notopen), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1383 return NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1384 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1385
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1386 smsg((char_u *)_("Reading affix file %s..."), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1387 out_flush();
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1388
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1389 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1390 * Allocate and init the afffile_T structure.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1391 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1392 aff = (afffile_T *)getroom(&spin->si_blocks, sizeof(afffile_T));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1393 if (aff == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1394 return NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1395 hash_init(&aff->af_pref);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1396 hash_init(&aff->af_suff);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1397 ga_init2(&aff->af_rep, (int)sizeof(repentry_T), 20);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1398
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1399 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1400 * Read all the lines in the file one by one.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1401 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1402 while (!vim_fgets(rline, MAXLINELEN, fd) && !got_int)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1403 {
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1404 line_breakcheck();
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1405 ++lnum;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1406
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1407 /* Skip comment lines. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1408 if (*rline == '#')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1409 continue;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1410
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1411 /* Convert from "SET" to 'encoding' when needed. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1412 vim_free(pc);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1413 if (spin->si_conv.vc_type != CONV_NONE)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1414 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1415 pc = string_convert(&spin->si_conv, rline, NULL);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1416 if (pc == NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1417 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1418 smsg((char_u *)_("Conversion failure for word in %s line %d: %s"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1419 fname, lnum, rline);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1420 continue;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1421 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1422 line = pc;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1423 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1424 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1425 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1426 pc = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1427 line = rline;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1428 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1429
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1430 /* Split the line up in white separated items. Put a NUL after each
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1431 * item. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1432 itemcnt = 0;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1433 for (p = line; ; )
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1434 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1435 while (*p != NUL && *p <= ' ') /* skip white space and CR/NL */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1436 ++p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1437 if (*p == NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1438 break;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1439 if (itemcnt == 6) /* too many items */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1440 break;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1441 items[itemcnt++] = p;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1442 while (*p > ' ') /* skip until white space or CR/NL */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1443 ++p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1444 if (*p == NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1445 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1446 *p++ = NUL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1447 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1448
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1449 /* Handle non-empty lines. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1450 if (itemcnt > 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1451 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1452 if (STRCMP(items[0], "SET") == 0 && itemcnt == 2
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1453 && aff->af_enc == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1454 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1455 /* Setup for conversion from "ENC" to 'encoding'. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1456 aff->af_enc = enc_canonize(items[1]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1457 if (aff->af_enc != NULL && !spin->si_ascii
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1458 && convert_setup(&spin->si_conv, aff->af_enc,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1459 p_enc) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1460 smsg((char_u *)_("Conversion in %s not supported: from %s to %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1461 fname, aff->af_enc, p_enc);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1462 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1463 else if (STRCMP(items[0], "TRY") == 0 && itemcnt == 2
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1464 && aff->af_try == NULL)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1465 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1466 aff->af_try = getroom_save(&spin->si_blocks, items[1]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1467 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1468 else if ((STRCMP(items[0], "PFX") == 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1469 || STRCMP(items[0], "SFX") == 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1470 && aff_todo == 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1471 && itemcnt == 4)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1472 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1473 /* New affix letter. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1474 cur_aff = (affheader_T *)getroom(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1475 sizeof(affheader_T));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1476 if (cur_aff == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1477 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1478 cur_aff->ah_key[0] = *items[1];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1479 cur_aff->ah_key[1] = NUL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1480 if (items[1][1] != NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1481 smsg((char_u *)_("Affix name too long in %s line %d: %s"),
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1482 fname, lnum, items[1]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1483 if (*items[2] == 'Y')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1484 cur_aff->ah_combine = TRUE;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1485 else if (*items[2] != 'N')
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1486 smsg((char_u *)_("Expected Y or N in %s line %d: %s"),
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1487 fname, lnum, items[2]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1488 if (*items[0] == 'P')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1489 tp = &aff->af_pref;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1490 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1491 tp = &aff->af_suff;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1492 aff_todo = atoi((char *)items[3]);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1493 if (!HASHITEM_EMPTY(hash_find(tp, cur_aff->ah_key)))
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1494 {
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1495 smsg((char_u *)_("Duplicate affix in %s line %d: %s"),
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1496 fname, lnum, items[1]);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1497 aff_todo = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1498 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1499 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1500 hash_add(tp, cur_aff->ah_key);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1501 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1502 else if ((STRCMP(items[0], "PFX") == 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1503 || STRCMP(items[0], "SFX") == 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1504 && aff_todo > 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1505 && STRCMP(cur_aff->ah_key, items[1]) == 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1506 && itemcnt == 5)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1507 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1508 affentry_T *aff_entry;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1509
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1510 /* New item for an affix letter. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1511 --aff_todo;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1512 aff_entry = (affentry_T *)getroom(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1513 sizeof(affentry_T));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1514 if (aff_entry == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1515 break;
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1516
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1517 if (STRCMP(items[2], "0") != 0)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1518 aff_entry->ae_chop = getroom_save(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1519 items[2]);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1520 if (STRCMP(items[3], "0") != 0)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1521 aff_entry->ae_add = getroom_save(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1522 items[3]);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1523
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1524 /* Don't use an affix entry with non-ASCII characters when
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1525 * "spin->si_ascii" is TRUE. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1526 if (!spin->si_ascii || !(has_non_ascii(aff_entry->ae_chop)
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1527 || has_non_ascii(aff_entry->ae_add)))
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1528 {
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1529 aff_entry->ae_next = cur_aff->ah_first;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1530 cur_aff->ah_first = aff_entry;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1531
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1532 if (STRCMP(items[4], ".") != 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1533 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1534 char_u buf[MAXLINELEN];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1535
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1536 aff_entry->ae_cond = getroom_save(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1537 items[4]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1538 if (*items[0] == 'P')
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1539 sprintf((char *)buf, "^%s", items[4]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1540 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1541 sprintf((char *)buf, "%s$", items[4]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1542 aff_entry->ae_prog = vim_regcomp(buf,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1543 RE_MAGIC + RE_STRING);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1544 }
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1545 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1546 }
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1547 else if (STRCMP(items[0], "FOL") == 0 && itemcnt == 2)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1548 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1549 if (fol != NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1550 smsg((char_u *)_("Duplicate FOL in %s line %d"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1551 fname, lnum);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1552 else
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1553 fol = vim_strsave(items[1]);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1554 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1555 else if (STRCMP(items[0], "LOW") == 0 && itemcnt == 2)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1556 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1557 if (low != NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1558 smsg((char_u *)_("Duplicate LOW in %s line %d"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1559 fname, lnum);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1560 else
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1561 low = vim_strsave(items[1]);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1562 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1563 else if (STRCMP(items[0], "UPP") == 0 && itemcnt == 2)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1564 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1565 if (upp != NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1566 smsg((char_u *)_("Duplicate UPP in %s line %d"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1567 fname, lnum);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1568 else
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1569 upp = vim_strsave(items[1]);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1570 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1571 else if (STRCMP(items[0], "REP") == 0 && itemcnt == 2)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1572 /* Ignore REP count */;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1573 else if (STRCMP(items[0], "REP") == 0 && itemcnt == 3)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1574 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1575 repentry_T *rp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1576
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1577 /* REP item */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1578 if (ga_grow(&aff->af_rep, 1) == FAIL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1579 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1580 rp = ((repentry_T *)aff->af_rep.ga_data) + aff->af_rep.ga_len;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1581 rp->re_from = getroom_save(&spin->si_blocks, items[1]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1582 rp->re_to = getroom_save(&spin->si_blocks, items[2]);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1583 ++aff->af_rep.ga_len;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1584 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1585 else
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1586 smsg((char_u *)_("Unrecognized item in %s line %d: %s"),
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1587 fname, lnum, items[0]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1588 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1589 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1590
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1591 if (fol != NULL || low != NULL || upp != NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1592 {
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1593 /* Don't write a word table for an ASCII file, so that we don't check
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1594 * for conflicts with a word table that matches 'encoding'. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1595 if (!spin->si_ascii)
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1596 {
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1597 if (fol == NULL || low == NULL || upp == NULL)
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1598 smsg((char_u *)_("Missing FOL/LOW/UPP line in %s"), fname);
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1599 else
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1600 set_spell_chartab(fol, low, upp);
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1601 }
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1602
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1603 vim_free(fol);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1604 vim_free(low);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1605 vim_free(upp);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1606 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1607
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1608 vim_free(pc);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1609 fclose(fd);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1610 return aff;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1611 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1612
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1613 /*
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1614 * Return TRUE if string "s" contains a non-ASCII character (128 or higher).
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1615 * When "s" is NULL FALSE is returned.
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1616 */
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1617 static int
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1618 has_non_ascii(s)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1619 char_u *s;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1620 {
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1621 char_u *p;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1622
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1623 if (s != NULL)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1624 for (p = s; *p != NUL; ++p)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1625 if (*p >= 128)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1626 return TRUE;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1627 return FALSE;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1628 }
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1629
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1630 /*
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1631 * Free the structure filled by spell_read_aff().
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1632 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1633 static void
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1634 spell_free_aff(aff)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1635 afffile_T *aff;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1636 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1637 hashtab_T *ht;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1638 hashitem_T *hi;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1639 int todo;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1640 affheader_T *ah;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1641 affentry_T *ae;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1642
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1643 vim_free(aff->af_enc);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1644
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1645 /* All this trouble to foree the "ae_prog" items... */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1646 for (ht = &aff->af_pref; ; ht = &aff->af_suff)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1647 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1648 todo = ht->ht_used;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1649 for (hi = ht->ht_array; todo > 0; ++hi)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1650 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1651 if (!HASHITEM_EMPTY(hi))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1652 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1653 --todo;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1654 ah = HI2AH(hi);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1655 for (ae = ah->ah_first; ae != NULL; ae = ae->ae_next)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1656 vim_free(ae->ae_prog);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1657 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1658 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1659 if (ht == &aff->af_suff)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1660 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1661 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1662
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1663 hash_clear(&aff->af_pref);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1664 hash_clear(&aff->af_suff);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1665 ga_clear(&aff->af_rep);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1666 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1667
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1668 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1669 * Read dictionary file "fname".
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1670 * Returns OK or FAIL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1671 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1672 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1673 spell_read_dic(fname, spin, affile)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1674 char_u *fname;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1675 spellinfo_T *spin;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1676 afffile_T *affile;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1677 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1678 hashtab_T ht;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1679 char_u line[MAXLINELEN];
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1680 char_u *afflist;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1681 char_u *dw;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1682 char_u *pc;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1683 char_u *w;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1684 int l;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1685 hash_T hash;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1686 hashitem_T *hi;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1687 FILE *fd;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1688 int lnum = 1;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1689 int non_ascii = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1690 int retval = OK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1691 char_u message[MAXLINELEN + MAXWLEN];
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1692
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1693 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1694 * Open the file.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1695 */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1696 fd = fopen((char *)fname, "r");
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1697 if (fd == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1698 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1699 EMSG2(_(e_notopen), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1700 return FAIL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1701 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1702
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1703 /* The hashtable is only used to detect duplicated words. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1704 hash_init(&ht);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1705
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1706 smsg((char_u *)_("Reading dictionary file %s..."), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1707 out_flush();
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1708
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1709 /* Read and ignore the first line: word count. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1710 (void)vim_fgets(line, MAXLINELEN, fd);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1711 if (!isdigit(*skipwhite(line)))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1712 EMSG2(_("E760: No word count in %s"), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1713
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1714 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1715 * Read all the lines in the file one by one.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1716 * The words are converted to 'encoding' here, before being added to
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1717 * the hashtable.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1718 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1719 while (!vim_fgets(line, MAXLINELEN, fd) && !got_int)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1720 {
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1721 line_breakcheck();
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1722 ++lnum;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1723
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1724 /* Remove CR, LF and white space from the end. White space halfway
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1725 * the word is kept to allow e.g., "et al.". */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1726 l = STRLEN(line);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1727 while (l > 0 && line[l - 1] <= ' ')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1728 --l;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1729 if (l == 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1730 continue; /* empty line */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1731 line[l] = NUL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1732
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1733 /* This takes time, print a message now and then. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1734 if ((lnum & 0x3ff) == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1735 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1736 vim_snprintf((char *)message, sizeof(message),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1737 _("line %6d - %s"), lnum, line);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1738 msg_start();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1739 msg_outtrans_attr(message, 0);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1740 msg_clr_eos();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1741 msg_didout = FALSE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1742 msg_col = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1743 out_flush();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1744 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1745
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1746 /* Find the optional affix names. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1747 afflist = vim_strchr(line, '/');
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1748 if (afflist != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1749 *afflist++ = NUL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1750
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1751 /* Skip non-ASCII words when "spin->si_ascii" is TRUE. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1752 if (spin->si_ascii && has_non_ascii(line))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1753 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1754 ++non_ascii;
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1755 continue;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1756 }
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1757
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1758 /* Convert from "SET" to 'encoding' when needed. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1759 if (spin->si_conv.vc_type != CONV_NONE)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1760 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1761 pc = string_convert(&spin->si_conv, line, NULL);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1762 if (pc == NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1763 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1764 smsg((char_u *)_("Conversion failure for word in %s line %d: %s"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1765 fname, lnum, line);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1766 continue;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1767 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1768 w = pc;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1769 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1770 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1771 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1772 pc = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1773 w = line;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1774 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1775
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1776 /* Store the word in the hashtable to be able to find duplicates. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1777 dw = (char_u *)getroom_save(&spin->si_blocks, w);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1778 if (dw == NULL)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1779 retval = FAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1780 vim_free(pc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1781 if (retval == FAIL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1782 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1783
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1784 hash = hash_hash(dw);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1785 hi = hash_lookup(&ht, dw, hash);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1786 if (!HASHITEM_EMPTY(hi))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1787 smsg((char_u *)_("Duplicate word in %s line %d: %s"),
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1788 fname, lnum, line);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1789 else
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1790 hash_add_item(&ht, hi, dw, hash);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1791
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1792 /* Add the word to the word tree(s). */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1793 if (store_word(dw, spin) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1794 retval = FAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1795
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1796 if (afflist != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1797 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1798 /* Find all matching suffixes and add the resulting words.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1799 * Additionally do matching prefixes that combine. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1800 if (store_aff_word(dw, spin, afflist,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1801 &affile->af_suff, &affile->af_pref, FALSE) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1802 retval = FAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1803
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1804 /* Find all matching prefixes and add the resulting words. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1805 if (store_aff_word(dw, spin, afflist,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1806 &affile->af_pref, NULL, FALSE) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1807 retval = FAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1808 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1809 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1810
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1811 if (spin->si_ascii && non_ascii > 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1812 smsg((char_u *)_("Ignored %d words with non-ASCII characters"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1813 non_ascii);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1814 hash_clear(&ht);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1815
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1816 fclose(fd);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1817 return retval;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1818 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1819
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1820 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1821 * Apply affixes to a word and store the resulting words.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1822 * "ht" is the hashtable with affentry_T that need to be applied, either
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1823 * prefixes or suffixes.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1824 * "xht", when not NULL, is the prefix hashtable, to be used additionally on
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1825 * the resulting words for combining affixes.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1826 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1827 * Returns FAIL when out of memory.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1828 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1829 static int
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1830 store_aff_word(word, spin, afflist, ht, xht, comb)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1831 char_u *word; /* basic word start */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1832 spellinfo_T *spin; /* spell info */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1833 char_u *afflist; /* list of names of supported affixes */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1834 hashtab_T *ht;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1835 hashtab_T *xht;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1836 int comb; /* only use affixes that combine */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1837 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1838 int todo;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1839 hashitem_T *hi;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1840 affheader_T *ah;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1841 affentry_T *ae;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1842 regmatch_T regmatch;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1843 char_u newword[MAXWLEN];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1844 int retval = OK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1845 int i;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1846 char_u *p;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1847
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1848 todo = ht->ht_used;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1849 for (hi = ht->ht_array; todo > 0 && retval == OK; ++hi)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1850 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1851 if (!HASHITEM_EMPTY(hi))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1852 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1853 --todo;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1854 ah = HI2AH(hi);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1855
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1856 /* Check that the affix combines, if required, and that the word
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1857 * supports this affix. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1858 if ((!comb || ah->ah_combine)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1859 && vim_strchr(afflist, *ah->ah_key) != NULL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1860 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1861 /* Loop over all affix entries with this name. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1862 for (ae = ah->ah_first; ae != NULL; ae = ae->ae_next)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1863 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1864 /* Check the condition. It's not logical to match case
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1865 * here, but it is required for compatibility with
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1866 * Myspell. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1867 regmatch.regprog = ae->ae_prog;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1868 regmatch.rm_ic = FALSE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1869 if (ae->ae_prog == NULL
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1870 || vim_regexec(&regmatch, word, (colnr_T)0))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1871 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1872 /* Match. Remove the chop and add the affix. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1873 if (xht == NULL)
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1874 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1875 /* prefix: chop/add at the start of the word */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1876 if (ae->ae_add == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1877 *newword = NUL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1878 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1879 STRCPY(newword, ae->ae_add);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1880 p = word;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1881 if (ae->ae_chop != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1882 /* Skip chop string. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1883 for (i = mb_charlen(ae->ae_chop); i > 0; --i)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1884 mb_ptr_adv(p);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1885 STRCAT(newword, p);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1886 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1887 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1888 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1889 /* suffix: chop/add at the end of the word */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1890 STRCPY(newword, word);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1891 if (ae->ae_chop != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1892 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1893 /* Remove chop string. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1894 p = newword + STRLEN(newword);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1895 for (i = mb_charlen(ae->ae_chop); i > 0; --i)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1896 mb_ptr_back(newword, p);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1897 *p = NUL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1898 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1899 if (ae->ae_add != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1900 STRCAT(newword, ae->ae_add);
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1901 }
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1902
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1903 /* Store the modified word. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1904 if (store_word(newword, spin) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1905 retval = FAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1906
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1907 /* When added a suffix and combining is allowed also
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1908 * try adding prefixes additionally. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1909 if (xht != NULL && ah->ah_combine)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1910 if (store_aff_word(newword, spin, afflist,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1911 xht, NULL, TRUE) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1912 retval = FAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1913 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1914 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1915 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1916 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1917 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1918
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1919 return retval;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1920 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1921
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1922 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1923 * Read a file with a list of words.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1924 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1925 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1926 spell_read_wordfile(fname, spin)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1927 char_u *fname;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1928 spellinfo_T *spin;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1929 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1930 FILE *fd;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1931 long lnum = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1932 char_u rline[MAXLINELEN];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1933 char_u *line;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1934 char_u *pc = NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1935 int l;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1936 int retval = OK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1937 int did_word = FALSE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1938 int non_ascii = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1939 char_u *enc;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1940
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1941 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1942 * Open the file.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1943 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1944 fd = fopen((char *)fname, "r");
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1945 if (fd == NULL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1946 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1947 EMSG2(_(e_notopen), fname);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1948 return FAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1949 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1950
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1951 smsg((char_u *)_("Reading word file %s..."), fname);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1952 out_flush();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1953
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1954 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1955 * Read all the lines in the file one by one.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1956 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1957 while (!vim_fgets(rline, MAXLINELEN, fd) && !got_int)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1958 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1959 line_breakcheck();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1960 ++lnum;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1961
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1962 /* Skip comment lines. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1963 if (*rline == '#')
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1964 continue;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1965
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1966 /* Remove CR, LF and white space from the end. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1967 l = STRLEN(rline);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1968 while (l > 0 && rline[l - 1] <= ' ')
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1969 --l;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1970 if (l == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1971 continue; /* empty or blank line */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1972 rline[l] = NUL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1973
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1974 /* Convert from "=encoding={encoding}" to 'encoding' when needed. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1975 vim_free(pc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1976 if (spin->si_conv.vc_type != CONV_NONE)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1977 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1978 pc = string_convert(&spin->si_conv, rline, NULL);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1979 if (pc == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1980 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1981 smsg((char_u *)_("Conversion failure for word in %s line %d: %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1982 fname, lnum, rline);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1983 continue;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1984 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1985 line = pc;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1986 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1987 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1988 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1989 pc = NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1990 line = rline;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1991 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1992
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1993 if (*line == '=')
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1994 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1995 if (STRNCMP(line + 1, "encoding=", 9) == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1996 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1997 if (spin->si_conv.vc_type != CONV_NONE)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1998 smsg((char_u *)_("Duplicate =encoding= line ignored in %s line %d: %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1999 fname, lnum, line);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2000 else if (did_word)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2001 smsg((char_u *)_("=encoding= line after word ignored in %s line %d: %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2002 fname, lnum, line);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2003 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2004 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2005 /* Setup for conversion to 'encoding'. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2006 enc = enc_canonize(line + 10);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2007 if (enc != NULL && !spin->si_ascii
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2008 && convert_setup(&spin->si_conv, enc,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2009 p_enc) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2010 smsg((char_u *)_("Conversion in %s not supported: from %s to %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2011 fname, line + 10, p_enc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2012 vim_free(enc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2013 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2014 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2015 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2016 smsg((char_u *)_("= line ignored in %s line %d: %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2017 fname, lnum, line);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2018 continue;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2019 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2020
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2021 /* Skip non-ASCII words when "spin->si_ascii" is TRUE. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2022 if (spin->si_ascii && has_non_ascii(line))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2023 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2024 ++non_ascii;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2025 continue;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2026 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2027
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2028 /* Normal word: store it. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2029 if (store_word(line, spin) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2030 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2031 retval = FAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2032 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2033 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2034 did_word = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2035 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2036
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2037 vim_free(pc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2038 fclose(fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2039
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2040 if (spin->si_ascii && non_ascii > 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2041 smsg((char_u *)_("Ignored %d words with non-ASCII characters"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2042 non_ascii);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2043 return retval;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2044 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2045
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2046 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2047 * Get part of an sblock_T, "len" bytes long.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2048 * This avoids calling free() for every little struct we use.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2049 * The memory is cleared to all zeros.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2050 * Returns NULL when out of memory.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2051 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2052 static void *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2053 getroom(blp, len)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2054 sblock_T **blp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2055 size_t len; /* length needed */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2056 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2057 char_u *p;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2058 sblock_T *bl = *blp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2059
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2060 if (bl == NULL || bl->sb_used + len > SBLOCKSIZE)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2061 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2062 /* Allocate a block of memory. This is not freed until much later. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2063 bl = (sblock_T *)alloc_clear((unsigned)(sizeof(sblock_T) + SBLOCKSIZE));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2064 if (bl == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2065 return NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2066 bl->sb_next = *blp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2067 *blp = bl;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2068 bl->sb_used = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2069 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2070
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2071 p = bl->sb_data + bl->sb_used;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2072 bl->sb_used += len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2073
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2074 return p;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2075 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2076
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2077 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2078 * Make a copy of a string into memory allocated with getroom().
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2079 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2080 static char_u *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2081 getroom_save(blp, s)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2082 sblock_T **blp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2083 char_u *s;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2084 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2085 char_u *sc;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2086
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2087 sc = (char_u *)getroom(blp, STRLEN(s) + 1);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2088 if (sc != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2089 STRCPY(sc, s);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2090 return sc;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2091 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2092
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2093
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2094 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2095 * Free the list of allocated sblock_T.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2096 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2097 static void
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2098 free_blocks(bl)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2099 sblock_T *bl;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2100 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2101 sblock_T *next;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2102
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2103 while (bl != NULL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2104 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2105 next = bl->sb_next;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2106 vim_free(bl);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2107 bl = next;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2108 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2109 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2110
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2111 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2112 * Allocate the root of a word tree.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2113 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2114 static wordnode_T *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2115 wordtree_alloc(blp)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2116 sblock_T **blp;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2117 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2118 return (wordnode_T *)getroom(blp, sizeof(wordnode_T));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2119 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2120
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2121 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2122 * Store a word in the tree(s).
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2123 * Always store it in the case-folded tree.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2124 * For a keep-case word also store it in the keep-case tree.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2125 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2126 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2127 store_word(word, spin)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2128 char_u *word;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2129 spellinfo_T *spin;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2130 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2131 int len = STRLEN(word);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2132 int ct = captype(word, word + len);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2133 char_u foldword[MAXWLEN];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2134 int res;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2135
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2136 (void)spell_casefold(word, len, foldword, MAXWLEN);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2137 res = tree_add_word(foldword, spin->si_foldroot, ct, spin->si_region,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2138 &spin->si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2139 if (res == OK && ct == WF_KEEPCAP)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2140 res = tree_add_word(word, spin->si_keeproot, ct, spin->si_region,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2141 &spin->si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2142 return res;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2143 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2144
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2145 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2146 * Add word "word" to a word tree at "root".
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2147 * Returns FAIL when out of memory.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2148 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2149 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2150 tree_add_word(word, root, flags, region, blp)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2151 char_u *word;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2152 wordnode_T *root;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2153 int flags;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2154 int region;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2155 sblock_T **blp;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2156 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2157 wordnode_T *node = root;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2158 wordnode_T *np;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2159 wordnode_T **prev = NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2160 int i;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2161
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2162 /* Add each byte of the word to the tree, including the NUL at the end. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2163 for (i = 0; ; ++i)
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2164 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2165 /* Look for the sibling that has the same character. They are sorted
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2166 * on byte value, thus stop searching when a sibling is found with a
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2167 * higher byte value. For zero bytes (end of word) check that the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2168 * flags are equal, there is a separate zero byte for each flag value.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2169 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2170 while (node != NULL && (node->wn_byte < word[i]
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2171 || (node->wn_byte == 0 && node->wn_flags != flags)))
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2172 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2173 prev = &node->wn_sibling;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2174 node = *prev;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2175 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2176 if (node == NULL || node->wn_byte != word[i])
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2177 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2178 /* Allocate a new node. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2179 np = (wordnode_T *)getroom(blp, sizeof(wordnode_T));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2180 if (np == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2181 return FAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2182 np->wn_byte = word[i];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2183 *prev = np;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2184 np->wn_sibling = node;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2185 node = np;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2186 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2187
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2188 if (word[i] == NUL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2189 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2190 node->wn_flags = flags;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2191 node->wn_region |= region;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2192 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2193 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2194 prev = &node->wn_child;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2195 node = *prev;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2196 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2197
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2198 return OK;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2199 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2200
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2201 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2202 * Compress a tree: find tails that are identical and can be shared.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2203 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2204 static void
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2205 wordtree_compress(root)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2206 wordnode_T *root;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2207 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2208 hashtab_T ht;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2209 int n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2210 int tot = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2211
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2212 if (root != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2213 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2214 hash_init(&ht);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2215 n = node_compress(root, &ht, &tot);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2216 smsg((char_u *)_("Compressed %d of %d nodes; %d%% remaining"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2217 n, tot, (tot - n) * 100 / tot);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2218 hash_clear(&ht);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2219 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2220 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2221
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2222 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2223 * Compress a node, its siblings and its children, depth first.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2224 * Returns the number of compressed nodes.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2225 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2226 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2227 node_compress(node, ht, tot)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2228 wordnode_T *node;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2229 hashtab_T *ht;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2230 int *tot; /* total count of nodes before compressing,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2231 incremented while going through the tree */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2232 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2233 wordnode_T *np;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2234 wordnode_T *tp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2235 wordnode_T *child;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2236 hash_T hash;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2237 hashitem_T *hi;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2238 int len = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2239 unsigned nr, n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2240 int compressed = 0;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2241
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2242 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2243 * Go through the list of siblings. Compress each child and then try
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2244 * finding an identical child to replace it.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2245 * Note that with "child" we mean not just the node that is pointed to,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2246 * but the whole list of siblings, of which the node is the first.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2247 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2248 for (np = node; np != NULL; np = np->wn_sibling)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2249 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2250 ++len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2251 if ((child = np->wn_child) != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2252 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2253 /* Compress the child. This fills wn_hashkey. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2254 compressed += node_compress(child, ht, tot);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2255
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2256 /* Try to find an identical child. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2257 hash = hash_hash(child->wn_hashkey);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2258 hi = hash_lookup(ht, child->wn_hashkey, hash);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2259 tp = NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2260 if (!HASHITEM_EMPTY(hi))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2261 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2262 /* There are children with an identical hash value. Now check
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2263 * if there is one that is really identical. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2264 for (tp = HI2WN(hi); tp != NULL; tp = tp->wn_next)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2265 if (node_equal(child, tp))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2266 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2267 /* Found one! Now use that child in place of the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2268 * current one. This means the current child is
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2269 * dropped from the tree. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2270 np->wn_child = tp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2271 ++compressed;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2272 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2273 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2274 if (tp == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2275 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2276 /* No other child with this hash value equals the child of
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2277 * the node, add it to the linked list after the first
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2278 * item. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2279 tp = HI2WN(hi);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2280 child->wn_next = tp->wn_next;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2281 tp->wn_next = child;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2282 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2283 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2284 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2285 /* No other child has this hash value, add it to the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2286 * hashtable. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2287 hash_add_item(ht, hi, child->wn_hashkey, hash);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2288 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2289 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2290 *tot += len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2291
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2292 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2293 * Make a hash key for the node and its siblings, so that we can quickly
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2294 * find a lookalike node. This must be done after compressing the sibling
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2295 * list, otherwise the hash key would become invalid by the compression.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2296 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2297 node->wn_hashkey[0] = len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2298 nr = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2299 for (np = node; np != NULL; np = np->wn_sibling)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2300 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2301 if (np->wn_byte == NUL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2302 /* end node: only use wn_flags and wn_region */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2303 n = np->wn_flags + (np->wn_region << 8);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2304 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2305 /* byte node: use the byte value and the child pointer */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2306 n = np->wn_byte + ((long_u)np->wn_child << 8);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2307 nr = nr * 101 + n;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2308 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2309
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2310 /* Avoid NUL bytes, it terminates the hash key. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2311 n = nr & 0xff;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2312 node->wn_hashkey[1] = n == 0 ? 1 : n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2313 n = (nr >> 8) & 0xff;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2314 node->wn_hashkey[2] = n == 0 ? 1 : n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2315 n = (nr >> 16) & 0xff;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2316 node->wn_hashkey[3] = n == 0 ? 1 : n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2317 n = (nr >> 24) & 0xff;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2318 node->wn_hashkey[4] = n == 0 ? 1 : n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2319 node->wn_hashkey[5] = NUL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2320
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2321 return compressed;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2322 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2323
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2324 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2325 * Return TRUE when two nodes have identical siblings and children.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2326 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2327 static int
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2328 node_equal(n1, n2)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2329 wordnode_T *n1;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2330 wordnode_T *n2;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2331 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2332 wordnode_T *p1;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2333 wordnode_T *p2;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2334
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2335 for (p1 = n1, p2 = n2; p1 != NULL && p2 != NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2336 p1 = p1->wn_sibling, p2 = p2->wn_sibling)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2337 if (p1->wn_byte != p2->wn_byte
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2338 || (p1->wn_byte == NUL
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2339 ? (p1->wn_flags != p2->wn_flags
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2340 || p1->wn_region != p2->wn_region)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2341 : (p1->wn_child != p2->wn_child)))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2342 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2343
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2344 return p1 == NULL && p2 == NULL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2345 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2346
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2347 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2348 * Write a number to file "fd", MSB first, in "len" bytes.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2349 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2350 void
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2351 put_bytes(fd, nr, len)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2352 FILE *fd;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2353 long_u nr;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2354 int len;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2355 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2356 int i;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2357
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2358 for (i = len - 1; i >= 0; --i)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2359 putc((int)(nr >> (i * 8)), fd);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2360 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2361
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2362 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2363 * Write the Vim spell file "fname".
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2364 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2365 static void
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2366 write_vim_spell(fname, spin, regcount, regchars)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2367 char_u *fname;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2368 spellinfo_T *spin;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2369 int regcount; /* number of regions */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2370 char_u *regchars; /* region names */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2371 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2372 FILE *fd;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2373 int regionmask;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2374 int round;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2375 wordnode_T *tree;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2376 int nodecount;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2377
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2378 fd = fopen((char *)fname, "w");
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2379 if (fd == NULL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2380 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2381 EMSG2(_(e_notopen), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2382 return;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2383 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2384
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2385 /* <HEADER>: <fileID> <regioncnt> <regionname> ...
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2386 * <charflagslen> <charflags> <fcharslen> <fchars> */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2387
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2388 /* <fileID> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2389 if (fwrite(VIMSPELLMAGIC, VIMSPELLMAGICL, (size_t)1, fd) != 1)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2390 EMSG(_(e_write));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2391
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2392 /* write the region names if there is more than one */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2393 if (regcount > 1)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2394 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2395 putc(regcount, fd); /* <regioncnt> <regionname> ... */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2396 fwrite(regchars, (size_t)(regcount * 2), (size_t)1, fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2397 regionmask = (1 << regcount) - 1;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2398 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2399 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2400 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2401 putc(0, fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2402 regionmask = 0;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2403 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2404
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2405 /* Write the table with character flags and table for case folding.
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2406 * <charflagslen> <charflags> <fcharlen> <fchars>
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2407 * Skip this for ASCII, the table may conflict with the one used for
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2408 * 'encoding'. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2409 if (spin->si_ascii)
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2410 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2411 putc(0, fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2412 putc(0, fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2413 putc(0, fd);
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2414 }
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2415 else
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2416 write_spell_chartab(fd);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2417
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2418
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2419 /* <SUGGEST> : <suggestlen> <more> ...
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2420 * TODO. Only write a zero length for now. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2421 put_bytes(fd, 0L, 4); /* <suggestlen> */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2422
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2423 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2424 * <LWORDTREE> <KWORDTREE>
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2425 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2426 for (round = 1; round <= 2; ++round)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2427 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2428 tree = (round == 1) ? spin->si_foldroot : spin->si_keeproot;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2429
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2430 /* Count the number of nodes. Needed to be able to allocate the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2431 * memory when reading the nodes. Also fills in the index for shared
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2432 * nodes. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2433 nodecount = put_tree(NULL, tree, 0, regionmask);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2434
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2435 /* number of nodes in 4 bytes */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2436 put_bytes(fd, (long_u)nodecount, 4); /* <nodecount> */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2437
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2438 /* Write the nodes. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2439 (void)put_tree(fd, tree, 0, regionmask);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2440 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2441
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2442 fclose(fd);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2443 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2444
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2445 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2446 * Dump a word tree at node "node".
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2447 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2448 * This first writes the list of possible bytes (siblings). Then for each
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2449 * byte recursively write the children.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2450 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2451 * NOTE: The code here must match the code in read_tree(), since assumptions
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2452 * are made about the indexes (so that we don't have to write them in the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2453 * file).
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2454 *
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2455 * Returns the number of nodes used.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2456 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2457 static int
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2458 put_tree(fd, node, index, regionmask)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2459 FILE *fd; /* NULL when only counting */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2460 wordnode_T *node;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2461 int index;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2462 int regionmask;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2463 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2464 int newindex = index;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2465 int siblingcount = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2466 wordnode_T *np;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2467 int flags;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2468
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2469 /* If "node" is zero the tree is empty. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2470 if (node == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2471 return 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2472
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2473 /* Store the index where this node is written. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2474 node->wn_index = index;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2475
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2476 /* Count the number of siblings. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2477 for (np = node; np != NULL; np = np->wn_sibling)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2478 ++siblingcount;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2479
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2480 /* Write the sibling count. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2481 if (fd != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2482 putc(siblingcount, fd); /* <siblingcount> */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2483
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2484 /* Write each sibling byte and optionally extra info. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2485 for (np = node; np != NULL; np = np->wn_sibling)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2486 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2487 if (np->wn_byte == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2488 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2489 if (fd != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2490 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2491 /* For a NUL byte (end of word) instead of the byte itself
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2492 * we write the flag/region items. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2493 flags = np->wn_flags;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2494 if (regionmask != 0 && np->wn_region != regionmask)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2495 flags |= WF_REGION;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2496 if (flags == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2497 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2498 /* word without flags or region */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2499 putc(BY_NOFLAGS, fd); /* <byte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2500 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2501 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2502 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2503 putc(BY_FLAGS, fd); /* <byte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2504 putc(flags, fd); /* <flags> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2505 if (flags & WF_REGION)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2506 putc(np->wn_region, fd); /* <regionmask> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2507 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2508 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2509 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2510 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2511 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2512 if (np->wn_child->wn_index != 0 && np->wn_child->wn_wnode != node)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2513 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2514 /* The child is written elsewhere, write the reference. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2515 if (fd != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2516 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2517 putc(BY_INDEX, fd); /* <byte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2518 /* <nodeidx> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2519 put_bytes(fd, (long_u)np->wn_child->wn_index, 3);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2520 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2521 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2522 else if (np->wn_child->wn_wnode == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2523 /* We will write the child below and give it an index. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2524 np->wn_child->wn_wnode = node;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2525
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2526 if (fd != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2527 if (putc(np->wn_byte, fd) == EOF) /* <byte> or <xbyte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2528 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2529 EMSG(_(e_write));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2530 return 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2531 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2532 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2533 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2534
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2535 /* Space used in the array when reading: one for each sibling and one for
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2536 * the count. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2537 newindex += siblingcount + 1;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
2538
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2539 /* Recursively dump the children of each sibling. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2540 for (np = node; np != NULL; np = np->wn_sibling)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2541 if (np->wn_byte != 0 && np->wn_child->wn_wnode == node)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2542 newindex = put_tree(fd, np->wn_child, newindex, regionmask);
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
2543
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2544 return newindex;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2545 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2546
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2547
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2548 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2549 * ":mkspell outfile infile ..."
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2550 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2551 void
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2552 ex_mkspell(eap)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2553 exarg_T *eap;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2554 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2555 int fcount;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2556 char_u **fnames;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2557 char_u fname[MAXPATHL];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2558 char_u wfname[MAXPATHL];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2559 afffile_T *(afile[8]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2560 int i;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2561 int len;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2562 char_u region_name[16];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2563 struct stat st;
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2564 char_u *arg = eap->arg;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2565 int error = FALSE;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2566 spellinfo_T spin;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2567
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2568 vim_memset(&spin, 0, sizeof(spin));
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2569
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2570 if (STRNCMP(arg, "-ascii", 6) == 0)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2571 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2572 spin.si_ascii = TRUE;
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2573 arg = skipwhite(arg + 6);
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2574 }
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2575
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2576 /* Expand all the remaining arguments (e.g., $VIMRUNTIME). */
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2577 if (get_arglist_exp(arg, &fcount, &fnames) == FAIL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2578 return;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2579 if (fcount < 2)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2580 EMSG(_(e_invarg)); /* need at least output and input names */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2581 else if (fcount > 9)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2582 EMSG(_("E754: Only up to 8 regions supported"));
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2583 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2584 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2585 /* Check for overwriting before doing things that may take a lot of
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2586 * time. */
272
ddada568db54 updated for version 7.0073
vimboss
parents: 260
diff changeset
2587 vim_snprintf((char *)wfname, sizeof(wfname), "%s.%s.spl", fnames[0],
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2588 spin.si_ascii ? (char_u *)"ascii" : p_enc);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2589 if (!eap->forceit && mch_stat((char *)wfname, &st) >= 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2590 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2591 EMSG(_(e_exists));
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2592 goto theend;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2593 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2594 if (mch_isdir(fnames[0]))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2595 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2596 EMSG2(_(e_isadir2), fnames[0]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2597 goto theend;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2598 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2599
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2600 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2601 * Init the aff and dic pointers.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2602 * Get the region names if there are more than 2 arguments.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2603 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2604 for (i = 1; i < fcount; ++i)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2605 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2606 afile[i - 1] = NULL;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2607
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2608 if (fcount > 2)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2609 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2610 len = STRLEN(fnames[i]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2611 if (STRLEN(gettail(fnames[i])) < 5 || fnames[i][len - 3] != '_')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2612 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2613 EMSG2(_("E755: Invalid region in %s"), fnames[i]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2614 goto theend;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2615 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2616 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2617 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2618 region_name[(i - 1) * 2] = TOLOWER_ASC(fnames[i][len - 2]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2619 region_name[(i - 1) * 2 + 1] =
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2620 TOLOWER_ASC(fnames[i][len - 1]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2621 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2622 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2623 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2624
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2625 /* Clear the char type tables, don't want to use any of the currently
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2626 * used spell properties. */
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2627 init_spell_chartab();
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2628
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2629 spin.si_foldroot = wordtree_alloc(&spin.si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2630 spin.si_keeproot = wordtree_alloc(&spin.si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2631 if (spin.si_foldroot == NULL || spin.si_keeproot == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2632 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2633 error = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2634 goto theend;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2635 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2636
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2637 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2638 * Read all the .aff and .dic files.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2639 * Text is converted to 'encoding'.
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2640 * Words are stored in the case-folded and keep-case trees.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2641 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2642 for (i = 1; i < fcount && !error; ++i)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2643 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2644 spin.si_conv.vc_type = CONV_NONE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2645 spin.si_region = 1 << (i - 1);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2646
272
ddada568db54 updated for version 7.0073
vimboss
parents: 260
diff changeset
2647 vim_snprintf((char *)fname, sizeof(fname), "%s.aff", fnames[i]);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2648 if (mch_stat((char *)fname, &st) >= 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2649 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2650 /* Read the .aff file. Will init "spin->si_conv" based on the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2651 * "SET" line. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2652 afile[i - 1] = spell_read_aff(fname, &spin);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2653 if (afile[i - 1] == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2654 error = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2655 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2656 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2657 /* Read the .dic file and store the words in the trees. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2658 vim_snprintf((char *)fname, sizeof(fname), "%s.dic",
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2659 fnames[i]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2660 if (spell_read_dic(fname, &spin, afile[i - 1]) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2661 error = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2662 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2663 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2664 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2665 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2666 /* No .aff file, try reading the file as a word list. Store
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2667 * the words in the trees. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2668 if (spell_read_wordfile(fnames[i], &spin) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2669 error = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2670 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2671
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2672 /* Free any conversion stuff. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2673 convert_setup(&spin.si_conv, NULL, NULL);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2674 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2675
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2676 if (!error)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2677 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2678 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2679 * Remove the dummy NUL from the start of the tree root.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2680 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2681 spin.si_foldroot = spin.si_foldroot->wn_sibling;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2682 spin.si_keeproot = spin.si_keeproot->wn_sibling;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2683
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2684 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2685 * Combine tails in the tree.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2686 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2687 MSG(_("Compressing word tree..."));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2688 out_flush();
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2689 wordtree_compress(spin.si_foldroot);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2690 wordtree_compress(spin.si_keeproot);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2691 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2692
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2693 if (!error)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2694 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2695 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2696 * Write the info in the spell file.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2697 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2698 smsg((char_u *)_("Writing spell file %s..."), wfname);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2699 out_flush();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2700 write_vim_spell(wfname, &spin, fcount - 1, region_name);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2701 MSG(_("Done!"));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2702 out_flush();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2703 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2704
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2705 /* Free the allocated memory. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2706 free_blocks(spin.si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2707
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2708 /* Free the .aff file structures. */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2709 for (i = 1; i < fcount; ++i)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2710 if (afile[i - 1] != NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2711 spell_free_aff(afile[i - 1]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2712 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2713
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2714 theend:
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2715 FreeWild(fcount, fnames);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2716 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2717
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2718 #endif /* FEAT_MBYTE */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2719
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2720
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2721 #endif /* FEAT_SYN_HL */