annotate src/spell.c @ 302:250611b3068d

updated for version 7.0080
author vimboss
date Sun, 05 Jun 2005 21:54:54 +0000
parents 86cd0a77d2ae
children 7010607c5753
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;
302
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
356 int valid = FALSE;
300
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' */
302
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
1331 int si_memtot; /* runtime memory used */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1332 } spellinfo_T;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
1333
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1334 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
1335 static int has_non_ascii __ARGS((char_u *s));
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1336 static void spell_free_aff __ARGS((afffile_T *aff));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1337 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
1338 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
1339 static int spell_read_wordfile __ARGS((char_u *fname, spellinfo_T *spin));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1340 static void *getroom __ARGS((sblock_T **blp, size_t len));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1341 static char_u *getroom_save __ARGS((sblock_T **blp, char_u *s));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1342 static void free_blocks __ARGS((sblock_T *bl));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1343 static wordnode_T *wordtree_alloc __ARGS((sblock_T **blp));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1344 static int store_word __ARGS((char_u *word, spellinfo_T *spin));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1345 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
1346 static void wordtree_compress __ARGS((wordnode_T *root));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1347 static int node_compress __ARGS((wordnode_T *node, hashtab_T *ht, int *tot));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1348 static int node_equal __ARGS((wordnode_T *n1, wordnode_T *n2));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1349 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
1350 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
1351
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1352 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1353 * Read an affix ".aff" file.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1354 * Returns an afffile_T, NULL for failure.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1355 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1356 static afffile_T *
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1357 spell_read_aff(fname, spin)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1358 char_u *fname;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1359 spellinfo_T *spin;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1360 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1361 FILE *fd;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1362 afffile_T *aff;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1363 char_u rline[MAXLINELEN];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1364 char_u *line;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1365 char_u *pc = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1366 char_u *(items[6]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1367 int itemcnt;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1368 char_u *p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1369 int lnum = 0;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1370 affheader_T *cur_aff = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1371 int aff_todo = 0;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1372 hashtab_T *tp;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1373 char_u *low = NULL;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1374 char_u *fol = NULL;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1375 char_u *upp = NULL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1376
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1377 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1378 * Open the file.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1379 */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1380 fd = fopen((char *)fname, "r");
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1381 if (fd == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1382 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1383 EMSG2(_(e_notopen), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1384 return NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1385 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1386
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1387 smsg((char_u *)_("Reading affix file %s..."), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1388 out_flush();
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1389
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1390 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1391 * Allocate and init the afffile_T structure.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1392 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1393 aff = (afffile_T *)getroom(&spin->si_blocks, sizeof(afffile_T));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1394 if (aff == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1395 return NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1396 hash_init(&aff->af_pref);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1397 hash_init(&aff->af_suff);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1398 ga_init2(&aff->af_rep, (int)sizeof(repentry_T), 20);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1399
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1400 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1401 * Read all the lines in the file one by one.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1402 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1403 while (!vim_fgets(rline, MAXLINELEN, fd) && !got_int)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1404 {
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1405 line_breakcheck();
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1406 ++lnum;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1407
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1408 /* Skip comment lines. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1409 if (*rline == '#')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1410 continue;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1411
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1412 /* Convert from "SET" to 'encoding' when needed. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1413 vim_free(pc);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1414 if (spin->si_conv.vc_type != CONV_NONE)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1415 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1416 pc = string_convert(&spin->si_conv, rline, NULL);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1417 if (pc == NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1418 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1419 smsg((char_u *)_("Conversion failure for word in %s line %d: %s"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1420 fname, lnum, rline);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1421 continue;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1422 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1423 line = pc;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1424 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1425 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1426 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1427 pc = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1428 line = rline;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1429 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1430
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1431 /* Split the line up in white separated items. Put a NUL after each
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1432 * item. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1433 itemcnt = 0;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1434 for (p = line; ; )
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1435 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1436 while (*p != NUL && *p <= ' ') /* skip white space and CR/NL */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1437 ++p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1438 if (*p == NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1439 break;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1440 if (itemcnt == 6) /* too many items */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1441 break;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1442 items[itemcnt++] = p;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1443 while (*p > ' ') /* skip until white space or CR/NL */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1444 ++p;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1445 if (*p == NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1446 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1447 *p++ = NUL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1448 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1449
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1450 /* Handle non-empty lines. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1451 if (itemcnt > 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1452 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1453 if (STRCMP(items[0], "SET") == 0 && itemcnt == 2
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1454 && aff->af_enc == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1455 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1456 /* Setup for conversion from "ENC" to 'encoding'. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1457 aff->af_enc = enc_canonize(items[1]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1458 if (aff->af_enc != NULL && !spin->si_ascii
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1459 && convert_setup(&spin->si_conv, aff->af_enc,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1460 p_enc) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1461 smsg((char_u *)_("Conversion in %s not supported: from %s to %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1462 fname, aff->af_enc, p_enc);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1463 }
302
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
1464 else if (STRCMP(items[0], "NOSPLITSUGS") == 0 && itemcnt == 1)
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
1465 {
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
1466 /* ignored */
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
1467 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1468 else if (STRCMP(items[0], "TRY") == 0 && itemcnt == 2
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1469 && aff->af_try == NULL)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1470 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1471 aff->af_try = getroom_save(&spin->si_blocks, items[1]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1472 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1473 else if ((STRCMP(items[0], "PFX") == 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1474 || STRCMP(items[0], "SFX") == 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1475 && aff_todo == 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1476 && itemcnt == 4)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1477 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1478 /* New affix letter. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1479 cur_aff = (affheader_T *)getroom(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1480 sizeof(affheader_T));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1481 if (cur_aff == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1482 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1483 cur_aff->ah_key[0] = *items[1];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1484 cur_aff->ah_key[1] = NUL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1485 if (items[1][1] != NUL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1486 smsg((char_u *)_("Affix name too long in %s line %d: %s"),
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1487 fname, lnum, items[1]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1488 if (*items[2] == 'Y')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1489 cur_aff->ah_combine = TRUE;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1490 else if (*items[2] != 'N')
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1491 smsg((char_u *)_("Expected Y or N in %s line %d: %s"),
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1492 fname, lnum, items[2]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1493 if (*items[0] == 'P')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1494 tp = &aff->af_pref;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1495 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1496 tp = &aff->af_suff;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1497 aff_todo = atoi((char *)items[3]);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1498 if (!HASHITEM_EMPTY(hash_find(tp, cur_aff->ah_key)))
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1499 {
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1500 smsg((char_u *)_("Duplicate affix in %s line %d: %s"),
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1501 fname, lnum, items[1]);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1502 aff_todo = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1503 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1504 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1505 hash_add(tp, cur_aff->ah_key);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1506 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1507 else if ((STRCMP(items[0], "PFX") == 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1508 || STRCMP(items[0], "SFX") == 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1509 && aff_todo > 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1510 && STRCMP(cur_aff->ah_key, items[1]) == 0
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1511 && itemcnt == 5)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1512 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1513 affentry_T *aff_entry;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1514
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1515 /* New item for an affix letter. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1516 --aff_todo;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1517 aff_entry = (affentry_T *)getroom(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1518 sizeof(affentry_T));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1519 if (aff_entry == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1520 break;
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1521
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1522 if (STRCMP(items[2], "0") != 0)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1523 aff_entry->ae_chop = getroom_save(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1524 items[2]);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1525 if (STRCMP(items[3], "0") != 0)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1526 aff_entry->ae_add = getroom_save(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1527 items[3]);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1528
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1529 /* Don't use an affix entry with non-ASCII characters when
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1530 * "spin->si_ascii" is TRUE. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1531 if (!spin->si_ascii || !(has_non_ascii(aff_entry->ae_chop)
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1532 || has_non_ascii(aff_entry->ae_add)))
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1533 {
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1534 aff_entry->ae_next = cur_aff->ah_first;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1535 cur_aff->ah_first = aff_entry;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1536
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1537 if (STRCMP(items[4], ".") != 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1538 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1539 char_u buf[MAXLINELEN];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1540
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1541 aff_entry->ae_cond = getroom_save(&spin->si_blocks,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1542 items[4]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1543 if (*items[0] == 'P')
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1544 sprintf((char *)buf, "^%s", items[4]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1545 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1546 sprintf((char *)buf, "%s$", items[4]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1547 aff_entry->ae_prog = vim_regcomp(buf,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1548 RE_MAGIC + RE_STRING);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1549 }
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1550 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1551 }
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1552 else if (STRCMP(items[0], "FOL") == 0 && itemcnt == 2)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1553 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1554 if (fol != NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1555 smsg((char_u *)_("Duplicate FOL in %s line %d"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1556 fname, lnum);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1557 else
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1558 fol = vim_strsave(items[1]);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1559 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1560 else if (STRCMP(items[0], "LOW") == 0 && itemcnt == 2)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1561 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1562 if (low != NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1563 smsg((char_u *)_("Duplicate LOW in %s line %d"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1564 fname, lnum);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1565 else
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1566 low = vim_strsave(items[1]);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1567 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1568 else if (STRCMP(items[0], "UPP") == 0 && itemcnt == 2)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1569 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1570 if (upp != NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1571 smsg((char_u *)_("Duplicate UPP in %s line %d"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1572 fname, lnum);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1573 else
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1574 upp = vim_strsave(items[1]);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1575 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1576 else if (STRCMP(items[0], "REP") == 0 && itemcnt == 2)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1577 /* Ignore REP count */;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1578 else if (STRCMP(items[0], "REP") == 0 && itemcnt == 3)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1579 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1580 repentry_T *rp;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1581
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1582 /* REP item */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1583 if (ga_grow(&aff->af_rep, 1) == FAIL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1584 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1585 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
1586 rp->re_from = getroom_save(&spin->si_blocks, items[1]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1587 rp->re_to = getroom_save(&spin->si_blocks, items[2]);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1588 ++aff->af_rep.ga_len;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1589 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1590 else
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1591 smsg((char_u *)_("Unrecognized item in %s line %d: %s"),
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1592 fname, lnum, items[0]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1593 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1594 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1595
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1596 if (fol != NULL || low != NULL || upp != NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1597 {
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1598 /* 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
1599 * for conflicts with a word table that matches 'encoding'. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1600 if (!spin->si_ascii)
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1601 {
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1602 if (fol == NULL || low == NULL || upp == NULL)
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1603 smsg((char_u *)_("Missing FOL/LOW/UPP line in %s"), fname);
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1604 else
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1605 set_spell_chartab(fol, low, upp);
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
1606 }
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1607
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1608 vim_free(fol);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1609 vim_free(low);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1610 vim_free(upp);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1611 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1612
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1613 vim_free(pc);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1614 fclose(fd);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1615 return aff;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1616 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1617
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1618 /*
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1619 * Return TRUE if string "s" contains a non-ASCII character (128 or higher).
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1620 * When "s" is NULL FALSE is returned.
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1621 */
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1622 static int
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1623 has_non_ascii(s)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1624 char_u *s;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1625 {
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1626 char_u *p;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1627
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1628 if (s != NULL)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1629 for (p = s; *p != NUL; ++p)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1630 if (*p >= 128)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1631 return TRUE;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1632 return FALSE;
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1633 }
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1634
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1635 /*
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1636 * Free the structure filled by spell_read_aff().
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1637 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1638 static void
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1639 spell_free_aff(aff)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1640 afffile_T *aff;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1641 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1642 hashtab_T *ht;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1643 hashitem_T *hi;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1644 int todo;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1645 affheader_T *ah;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1646 affentry_T *ae;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1647
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1648 vim_free(aff->af_enc);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1649
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1650 /* All this trouble to foree the "ae_prog" items... */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1651 for (ht = &aff->af_pref; ; ht = &aff->af_suff)
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 = ht->ht_used;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1654 for (hi = ht->ht_array; todo > 0; ++hi)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1655 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1656 if (!HASHITEM_EMPTY(hi))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1657 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1658 --todo;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1659 ah = HI2AH(hi);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1660 for (ae = ah->ah_first; ae != NULL; ae = ae->ae_next)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1661 vim_free(ae->ae_prog);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1662 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1663 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1664 if (ht == &aff->af_suff)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1665 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1666 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1667
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1668 hash_clear(&aff->af_pref);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1669 hash_clear(&aff->af_suff);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1670 ga_clear(&aff->af_rep);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1671 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1672
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1673 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1674 * Read dictionary file "fname".
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1675 * Returns OK or FAIL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1676 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1677 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1678 spell_read_dic(fname, spin, affile)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1679 char_u *fname;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1680 spellinfo_T *spin;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1681 afffile_T *affile;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1682 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1683 hashtab_T ht;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1684 char_u line[MAXLINELEN];
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1685 char_u *afflist;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1686 char_u *dw;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1687 char_u *pc;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1688 char_u *w;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1689 int l;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1690 hash_T hash;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1691 hashitem_T *hi;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1692 FILE *fd;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1693 int lnum = 1;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1694 int non_ascii = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1695 int retval = OK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1696 char_u message[MAXLINELEN + MAXWLEN];
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1697
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1698 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1699 * Open the file.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1700 */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1701 fd = fopen((char *)fname, "r");
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1702 if (fd == NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1703 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1704 EMSG2(_(e_notopen), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1705 return FAIL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1706 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1707
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1708 /* The hashtable is only used to detect duplicated words. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1709 hash_init(&ht);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1710
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1711 smsg((char_u *)_("Reading dictionary file %s..."), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1712 out_flush();
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1713
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1714 /* Read and ignore the first line: word count. */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1715 (void)vim_fgets(line, MAXLINELEN, fd);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1716 if (!isdigit(*skipwhite(line)))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1717 EMSG2(_("E760: No word count in %s"), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1718
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1719 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1720 * Read all the lines in the file one by one.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1721 * The words are converted to 'encoding' here, before being added to
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1722 * the hashtable.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1723 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1724 while (!vim_fgets(line, MAXLINELEN, fd) && !got_int)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1725 {
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1726 line_breakcheck();
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1727 ++lnum;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1728
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1729 /* Remove CR, LF and white space from the end. White space halfway
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1730 * the word is kept to allow e.g., "et al.". */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1731 l = STRLEN(line);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1732 while (l > 0 && line[l - 1] <= ' ')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1733 --l;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1734 if (l == 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1735 continue; /* empty line */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1736 line[l] = NUL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1737
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1738 /* This takes time, print a message now and then. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1739 if ((lnum & 0x3ff) == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1740 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1741 vim_snprintf((char *)message, sizeof(message),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1742 _("line %6d - %s"), lnum, line);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1743 msg_start();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1744 msg_outtrans_attr(message, 0);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1745 msg_clr_eos();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1746 msg_didout = FALSE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1747 msg_col = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1748 out_flush();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1749 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1750
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1751 /* Find the optional affix names. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1752 afflist = vim_strchr(line, '/');
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1753 if (afflist != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1754 *afflist++ = NUL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1755
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1756 /* Skip non-ASCII words when "spin->si_ascii" is TRUE. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1757 if (spin->si_ascii && has_non_ascii(line))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1758 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1759 ++non_ascii;
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1760 continue;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1761 }
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1762
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1763 /* Convert from "SET" to 'encoding' when needed. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1764 if (spin->si_conv.vc_type != CONV_NONE)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1765 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1766 pc = string_convert(&spin->si_conv, line, NULL);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1767 if (pc == NULL)
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1768 {
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1769 smsg((char_u *)_("Conversion failure for word in %s line %d: %s"),
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1770 fname, lnum, line);
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1771 continue;
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
1772 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1773 w = pc;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1774 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1775 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1776 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1777 pc = NULL;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1778 w = line;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1779 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1780
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1781 /* Store the word in the hashtable to be able to find duplicates. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1782 dw = (char_u *)getroom_save(&spin->si_blocks, w);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1783 if (dw == NULL)
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1784 retval = FAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1785 vim_free(pc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1786 if (retval == FAIL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1787 break;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1788
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1789 hash = hash_hash(dw);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1790 hi = hash_lookup(&ht, dw, hash);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1791 if (!HASHITEM_EMPTY(hi))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1792 smsg((char_u *)_("Duplicate word in %s line %d: %s"),
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1793 fname, lnum, line);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1794 else
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1795 hash_add_item(&ht, hi, dw, hash);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1796
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1797 /* Add the word to the word tree(s). */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1798 if (store_word(dw, spin) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1799 retval = FAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1800
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1801 if (afflist != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1802 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1803 /* Find all matching suffixes and add the resulting words.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1804 * Additionally do matching prefixes that combine. */
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_suff, &affile->af_pref, 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
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1809 /* Find all matching prefixes and add the resulting words. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1810 if (store_aff_word(dw, spin, afflist,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1811 &affile->af_pref, NULL, FALSE) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1812 retval = FAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1813 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1814 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1815
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1816 if (spin->si_ascii && non_ascii > 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1817 smsg((char_u *)_("Ignored %d words with non-ASCII characters"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1818 non_ascii);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1819 hash_clear(&ht);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1820
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1821 fclose(fd);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1822 return retval;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1823 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1824
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1825 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1826 * Apply affixes to a word and store the resulting words.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1827 * "ht" is the hashtable with affentry_T that need to be applied, either
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1828 * prefixes or suffixes.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1829 * "xht", when not NULL, is the prefix hashtable, to be used additionally on
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1830 * the resulting words for combining affixes.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1831 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1832 * Returns FAIL when out of memory.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1833 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1834 static int
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1835 store_aff_word(word, spin, afflist, ht, xht, comb)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1836 char_u *word; /* basic word start */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1837 spellinfo_T *spin; /* spell info */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1838 char_u *afflist; /* list of names of supported affixes */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1839 hashtab_T *ht;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1840 hashtab_T *xht;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1841 int comb; /* only use affixes that combine */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1842 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1843 int todo;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1844 hashitem_T *hi;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1845 affheader_T *ah;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1846 affentry_T *ae;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1847 regmatch_T regmatch;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1848 char_u newword[MAXWLEN];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1849 int retval = OK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1850 int i;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1851 char_u *p;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1852
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1853 todo = ht->ht_used;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1854 for (hi = ht->ht_array; todo > 0 && retval == OK; ++hi)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1855 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1856 if (!HASHITEM_EMPTY(hi))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1857 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1858 --todo;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1859 ah = HI2AH(hi);
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 /* Check that the affix combines, if required, and that the word
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1862 * supports this affix. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1863 if ((!comb || ah->ah_combine)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1864 && vim_strchr(afflist, *ah->ah_key) != NULL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1865 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1866 /* Loop over all affix entries with this name. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1867 for (ae = ah->ah_first; ae != NULL; ae = ae->ae_next)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1868 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1869 /* Check the condition. It's not logical to match case
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1870 * here, but it is required for compatibility with
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1871 * Myspell. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1872 regmatch.regprog = ae->ae_prog;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1873 regmatch.rm_ic = FALSE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1874 if (ae->ae_prog == NULL
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1875 || vim_regexec(&regmatch, word, (colnr_T)0))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1876 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1877 /* Match. Remove the chop and add the affix. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1878 if (xht == NULL)
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1879 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1880 /* prefix: chop/add at the start of the word */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1881 if (ae->ae_add == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1882 *newword = NUL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1883 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1884 STRCPY(newword, ae->ae_add);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1885 p = word;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1886 if (ae->ae_chop != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1887 /* Skip chop string. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1888 for (i = mb_charlen(ae->ae_chop); i > 0; --i)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1889 mb_ptr_adv(p);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1890 STRCAT(newword, p);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1891 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1892 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1893 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1894 /* suffix: chop/add at the end of the word */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1895 STRCPY(newword, word);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1896 if (ae->ae_chop != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1897 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1898 /* Remove chop string. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1899 p = newword + STRLEN(newword);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1900 for (i = mb_charlen(ae->ae_chop); i > 0; --i)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1901 mb_ptr_back(newword, p);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1902 *p = NUL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1903 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1904 if (ae->ae_add != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1905 STRCAT(newword, ae->ae_add);
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1906 }
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
1907
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1908 /* Store the modified word. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1909 if (store_word(newword, spin) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1910 retval = FAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1911
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1912 /* When added a suffix and combining is allowed also
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1913 * try adding prefixes additionally. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1914 if (xht != NULL && ah->ah_combine)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1915 if (store_aff_word(newword, spin, afflist,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1916 xht, NULL, TRUE) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1917 retval = FAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1918 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1919 }
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 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1923
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1924 return retval;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1925 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1926
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1927 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1928 * Read a file with a list of words.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1929 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1930 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1931 spell_read_wordfile(fname, spin)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1932 char_u *fname;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1933 spellinfo_T *spin;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1934 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1935 FILE *fd;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1936 long lnum = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1937 char_u rline[MAXLINELEN];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1938 char_u *line;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1939 char_u *pc = NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1940 int l;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1941 int retval = OK;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1942 int did_word = FALSE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1943 int non_ascii = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1944 char_u *enc;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1945
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1946 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1947 * Open the file.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1948 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1949 fd = fopen((char *)fname, "r");
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1950 if (fd == NULL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1951 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1952 EMSG2(_(e_notopen), fname);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1953 return FAIL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1954 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
1955
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1956 smsg((char_u *)_("Reading word file %s..."), fname);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1957 out_flush();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1958
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1959 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1960 * Read all the lines in the file one by one.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1961 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1962 while (!vim_fgets(rline, MAXLINELEN, fd) && !got_int)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1963 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1964 line_breakcheck();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1965 ++lnum;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1966
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1967 /* Skip comment lines. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1968 if (*rline == '#')
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1969 continue;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1970
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1971 /* Remove CR, LF and white space from the end. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1972 l = STRLEN(rline);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1973 while (l > 0 && rline[l - 1] <= ' ')
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1974 --l;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1975 if (l == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1976 continue; /* empty or blank line */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1977 rline[l] = NUL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1978
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1979 /* Convert from "=encoding={encoding}" to 'encoding' when needed. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1980 vim_free(pc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1981 if (spin->si_conv.vc_type != CONV_NONE)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1982 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1983 pc = string_convert(&spin->si_conv, rline, NULL);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1984 if (pc == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1985 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1986 smsg((char_u *)_("Conversion failure for word in %s line %d: %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1987 fname, lnum, rline);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1988 continue;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1989 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1990 line = pc;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1991 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1992 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1993 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1994 pc = NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1995 line = rline;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1996 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1997
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1998 if (*line == '=')
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
1999 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2000 if (STRNCMP(line + 1, "encoding=", 9) == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2001 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2002 if (spin->si_conv.vc_type != CONV_NONE)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2003 smsg((char_u *)_("Duplicate =encoding= line ignored in %s line %d: %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2004 fname, lnum, line);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2005 else if (did_word)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2006 smsg((char_u *)_("=encoding= line after word ignored in %s line %d: %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2007 fname, lnum, line);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2008 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2009 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2010 /* Setup for conversion to 'encoding'. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2011 enc = enc_canonize(line + 10);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2012 if (enc != NULL && !spin->si_ascii
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2013 && convert_setup(&spin->si_conv, enc,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2014 p_enc) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2015 smsg((char_u *)_("Conversion in %s not supported: from %s to %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2016 fname, line + 10, p_enc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2017 vim_free(enc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2018 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2019 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2020 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2021 smsg((char_u *)_("= line ignored in %s line %d: %s"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2022 fname, lnum, line);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2023 continue;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2024 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2025
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2026 /* Skip non-ASCII words when "spin->si_ascii" is TRUE. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2027 if (spin->si_ascii && has_non_ascii(line))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2028 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2029 ++non_ascii;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2030 continue;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2031 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2032
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2033 /* Normal word: store it. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2034 if (store_word(line, spin) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2035 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2036 retval = FAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2037 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2038 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2039 did_word = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2040 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2041
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2042 vim_free(pc);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2043 fclose(fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2044
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2045 if (spin->si_ascii && non_ascii > 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2046 smsg((char_u *)_("Ignored %d words with non-ASCII characters"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2047 non_ascii);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2048 return retval;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2049 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2050
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2051 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2052 * Get part of an sblock_T, "len" bytes long.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2053 * This avoids calling free() for every little struct we use.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2054 * The memory is cleared to all zeros.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2055 * Returns NULL when out of memory.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2056 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2057 static void *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2058 getroom(blp, len)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2059 sblock_T **blp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2060 size_t len; /* length needed */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2061 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2062 char_u *p;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2063 sblock_T *bl = *blp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2064
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2065 if (bl == NULL || bl->sb_used + len > SBLOCKSIZE)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2066 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2067 /* Allocate a block of memory. This is not freed until much later. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2068 bl = (sblock_T *)alloc_clear((unsigned)(sizeof(sblock_T) + SBLOCKSIZE));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2069 if (bl == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2070 return NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2071 bl->sb_next = *blp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2072 *blp = bl;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2073 bl->sb_used = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2074 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2075
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2076 p = bl->sb_data + bl->sb_used;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2077 bl->sb_used += len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2078
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2079 return p;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2080 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2081
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2082 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2083 * Make a copy of a string into memory allocated with getroom().
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2084 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2085 static char_u *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2086 getroom_save(blp, s)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2087 sblock_T **blp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2088 char_u *s;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2089 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2090 char_u *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 sc = (char_u *)getroom(blp, STRLEN(s) + 1);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2093 if (sc != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2094 STRCPY(sc, s);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2095 return sc;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2096 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2097
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2098
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2099 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2100 * Free the list of allocated sblock_T.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2101 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2102 static void
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2103 free_blocks(bl)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2104 sblock_T *bl;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2105 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2106 sblock_T *next;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2107
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2108 while (bl != NULL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2109 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2110 next = bl->sb_next;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2111 vim_free(bl);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2112 bl = next;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2113 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2114 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2115
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2116 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2117 * Allocate the root of a word tree.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2118 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2119 static wordnode_T *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2120 wordtree_alloc(blp)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2121 sblock_T **blp;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2122 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2123 return (wordnode_T *)getroom(blp, sizeof(wordnode_T));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2124 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2125
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2126 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2127 * Store a word in the tree(s).
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2128 * Always store it in the case-folded tree.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2129 * 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
2130 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2131 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2132 store_word(word, spin)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2133 char_u *word;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2134 spellinfo_T *spin;
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 int len = STRLEN(word);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2137 int ct = captype(word, word + len);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2138 char_u foldword[MAXWLEN];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2139 int res;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2140
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2141 (void)spell_casefold(word, len, foldword, MAXWLEN);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2142 res = tree_add_word(foldword, spin->si_foldroot, ct, spin->si_region,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2143 &spin->si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2144 if (res == OK && ct == WF_KEEPCAP)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2145 res = tree_add_word(word, spin->si_keeproot, ct, spin->si_region,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2146 &spin->si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2147 return res;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2148 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2149
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2150 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2151 * Add word "word" to a word tree at "root".
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2152 * Returns FAIL when out of memory.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2153 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2154 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2155 tree_add_word(word, root, flags, region, blp)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2156 char_u *word;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2157 wordnode_T *root;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2158 int flags;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2159 int region;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2160 sblock_T **blp;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2161 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2162 wordnode_T *node = root;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2163 wordnode_T *np;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2164 wordnode_T **prev = NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2165 int i;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2166
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2167 /* 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
2168 for (i = 0; ; ++i)
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2169 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2170 /* Look for the sibling that has the same character. They are sorted
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2171 * on byte value, thus stop searching when a sibling is found with a
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2172 * higher byte value. For zero bytes (end of word) check that the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2173 * flags are equal, there is a separate zero byte for each flag value.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2174 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2175 while (node != NULL && (node->wn_byte < word[i]
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2176 || (node->wn_byte == 0 && node->wn_flags != flags)))
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2177 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2178 prev = &node->wn_sibling;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2179 node = *prev;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2180 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2181 if (node == NULL || node->wn_byte != word[i])
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2182 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2183 /* Allocate a new node. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2184 np = (wordnode_T *)getroom(blp, sizeof(wordnode_T));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2185 if (np == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2186 return FAIL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2187 np->wn_byte = word[i];
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2188 *prev = np;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2189 np->wn_sibling = node;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2190 node = np;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2191 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2192
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2193 if (word[i] == NUL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2194 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2195 node->wn_flags = flags;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2196 node->wn_region |= region;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2197 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2198 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2199 prev = &node->wn_child;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2200 node = *prev;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2201 }
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2202
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2203 return OK;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2204 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2205
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2206 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2207 * Compress a tree: find tails that are identical and can be shared.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2208 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2209 static void
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2210 wordtree_compress(root)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2211 wordnode_T *root;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2212 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2213 hashtab_T ht;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2214 int n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2215 int tot = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2216
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2217 if (root != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2218 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2219 hash_init(&ht);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2220 n = node_compress(root, &ht, &tot);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2221 smsg((char_u *)_("Compressed %d of %d nodes; %d%% remaining"),
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2222 n, tot, (tot - n) * 100 / tot);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2223 hash_clear(&ht);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2224 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2225 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2226
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2227 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2228 * Compress a node, its siblings and its children, depth first.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2229 * Returns the number of compressed nodes.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2230 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2231 static int
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2232 node_compress(node, ht, tot)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2233 wordnode_T *node;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2234 hashtab_T *ht;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2235 int *tot; /* total count of nodes before compressing,
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2236 incremented while going through the tree */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2237 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2238 wordnode_T *np;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2239 wordnode_T *tp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2240 wordnode_T *child;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2241 hash_T hash;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2242 hashitem_T *hi;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2243 int len = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2244 unsigned nr, n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2245 int compressed = 0;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2246
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2247 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2248 * Go through the list of siblings. Compress each child and then try
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2249 * finding an identical child to replace it.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2250 * 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
2251 * but the whole list of siblings, of which the node is the first.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2252 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2253 for (np = node; np != NULL; np = np->wn_sibling)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2254 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2255 ++len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2256 if ((child = np->wn_child) != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2257 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2258 /* Compress the child. This fills wn_hashkey. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2259 compressed += node_compress(child, ht, tot);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2260
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2261 /* Try to find an identical child. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2262 hash = hash_hash(child->wn_hashkey);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2263 hi = hash_lookup(ht, child->wn_hashkey, hash);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2264 tp = NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2265 if (!HASHITEM_EMPTY(hi))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2266 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2267 /* There are children with an identical hash value. Now check
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2268 * if there is one that is really identical. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2269 for (tp = HI2WN(hi); tp != NULL; tp = tp->wn_next)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2270 if (node_equal(child, tp))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2271 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2272 /* Found one! Now use that child in place of the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2273 * current one. This means the current child is
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2274 * dropped from the tree. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2275 np->wn_child = tp;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2276 ++compressed;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2277 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2278 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2279 if (tp == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2280 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2281 /* No other child with this hash value equals the child of
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2282 * the node, add it to the linked list after the first
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2283 * item. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2284 tp = HI2WN(hi);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2285 child->wn_next = tp->wn_next;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2286 tp->wn_next = child;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2287 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2288 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2289 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2290 /* No other child has this hash value, add it to the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2291 * hashtable. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2292 hash_add_item(ht, hi, child->wn_hashkey, hash);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2293 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2294 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2295 *tot += len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2296
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2297 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2298 * 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
2299 * find a lookalike node. This must be done after compressing the sibling
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2300 * list, otherwise the hash key would become invalid by the compression.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2301 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2302 node->wn_hashkey[0] = len;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2303 nr = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2304 for (np = node; np != NULL; np = np->wn_sibling)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2305 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2306 if (np->wn_byte == NUL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2307 /* end node: only use wn_flags and wn_region */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2308 n = np->wn_flags + (np->wn_region << 8);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2309 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2310 /* byte node: use the byte value and the child pointer */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2311 n = np->wn_byte + ((long_u)np->wn_child << 8);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2312 nr = nr * 101 + n;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2313 }
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2314
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2315 /* Avoid NUL bytes, it terminates the hash key. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2316 n = nr & 0xff;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2317 node->wn_hashkey[1] = n == 0 ? 1 : n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2318 n = (nr >> 8) & 0xff;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2319 node->wn_hashkey[2] = n == 0 ? 1 : n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2320 n = (nr >> 16) & 0xff;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2321 node->wn_hashkey[3] = n == 0 ? 1 : n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2322 n = (nr >> 24) & 0xff;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2323 node->wn_hashkey[4] = n == 0 ? 1 : n;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2324 node->wn_hashkey[5] = NUL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2325
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2326 return compressed;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2327 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2328
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2329 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2330 * Return TRUE when two nodes have identical siblings and children.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2331 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2332 static int
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2333 node_equal(n1, n2)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2334 wordnode_T *n1;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2335 wordnode_T *n2;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2336 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2337 wordnode_T *p1;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2338 wordnode_T *p2;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2339
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2340 for (p1 = n1, p2 = n2; p1 != NULL && p2 != NULL;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2341 p1 = p1->wn_sibling, p2 = p2->wn_sibling)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2342 if (p1->wn_byte != p2->wn_byte
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2343 || (p1->wn_byte == NUL
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2344 ? (p1->wn_flags != p2->wn_flags
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2345 || p1->wn_region != p2->wn_region)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2346 : (p1->wn_child != p2->wn_child)))
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2347 break;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2348
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2349 return p1 == NULL && p2 == NULL;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2350 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2351
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2352 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2353 * Write a number to file "fd", MSB first, in "len" bytes.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2354 */
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2355 void
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2356 put_bytes(fd, nr, len)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2357 FILE *fd;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2358 long_u nr;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2359 int len;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2360 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2361 int i;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2362
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2363 for (i = len - 1; i >= 0; --i)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2364 putc((int)(nr >> (i * 8)), fd);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2365 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2366
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2367 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2368 * Write the Vim spell file "fname".
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2369 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2370 static void
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2371 write_vim_spell(fname, spin, regcount, regchars)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2372 char_u *fname;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2373 spellinfo_T *spin;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2374 int regcount; /* number of regions */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2375 char_u *regchars; /* region names */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2376 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2377 FILE *fd;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2378 int regionmask;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2379 int round;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2380 wordnode_T *tree;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2381 int nodecount;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2382
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2383 fd = fopen((char *)fname, "w");
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2384 if (fd == NULL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2385 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2386 EMSG2(_(e_notopen), fname);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2387 return;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2388 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2389
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2390 /* <HEADER>: <fileID> <regioncnt> <regionname> ...
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2391 * <charflagslen> <charflags> <fcharslen> <fchars> */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2392
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2393 /* <fileID> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2394 if (fwrite(VIMSPELLMAGIC, VIMSPELLMAGICL, (size_t)1, fd) != 1)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2395 EMSG(_(e_write));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2396
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2397 /* write the region names if there is more than one */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2398 if (regcount > 1)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2399 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2400 putc(regcount, fd); /* <regioncnt> <regionname> ... */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2401 fwrite(regchars, (size_t)(regcount * 2), (size_t)1, fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2402 regionmask = (1 << regcount) - 1;
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 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2405 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2406 putc(0, fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2407 regionmask = 0;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2408 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2409
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2410 /* Write the table with character flags and table for case folding.
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2411 * <charflagslen> <charflags> <fcharlen> <fchars>
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2412 * Skip this for ASCII, the table may conflict with the one used for
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2413 * 'encoding'. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2414 if (spin->si_ascii)
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2415 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2416 putc(0, fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2417 putc(0, fd);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2418 putc(0, fd);
260
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2419 }
ed33f83b42d8 updated for version 7.0071
vimboss
parents: 255
diff changeset
2420 else
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2421 write_spell_chartab(fd);
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2422
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2423
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2424 /* <SUGGEST> : <suggestlen> <more> ...
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2425 * TODO. Only write a zero length for now. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2426 put_bytes(fd, 0L, 4); /* <suggestlen> */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2427
302
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
2428 spin->si_memtot = 0;
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
2429
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2430 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2431 * <LWORDTREE> <KWORDTREE>
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2432 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2433 for (round = 1; round <= 2; ++round)
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 tree = (round == 1) ? spin->si_foldroot : spin->si_keeproot;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2436
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2437 /* Count the number of nodes. Needed to be able to allocate the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2438 * memory when reading the nodes. Also fills in the index for shared
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2439 * nodes. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2440 nodecount = put_tree(NULL, tree, 0, regionmask);
236
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 /* number of nodes in 4 bytes */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2443 put_bytes(fd, (long_u)nodecount, 4); /* <nodecount> */
302
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
2444 spin->si_memtot += nodecount + nodecount * sizeof(int);
236
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 /* Write the nodes. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2447 (void)put_tree(fd, tree, 0, regionmask);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2448 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2449
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2450 fclose(fd);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2451 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2452
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2453 /*
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2454 * Dump a word tree at node "node".
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2455 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2456 * This first writes the list of possible bytes (siblings). Then for each
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2457 * byte recursively write the children.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2458 *
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2459 * NOTE: The code here must match the code in read_tree(), since assumptions
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2460 * 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
2461 * file).
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2462 *
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2463 * Returns the number of nodes used.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2464 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2465 static int
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2466 put_tree(fd, node, index, regionmask)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2467 FILE *fd; /* NULL when only counting */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2468 wordnode_T *node;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2469 int index;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2470 int regionmask;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2471 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2472 int newindex = index;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2473 int siblingcount = 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2474 wordnode_T *np;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2475 int flags;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2476
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2477 /* If "node" is zero the tree is empty. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2478 if (node == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2479 return 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2480
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2481 /* Store the index where this node is written. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2482 node->wn_index = index;
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 /* Count the number of siblings. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2485 for (np = node; np != NULL; np = np->wn_sibling)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2486 ++siblingcount;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2487
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2488 /* Write the sibling count. */
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 putc(siblingcount, fd); /* <siblingcount> */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2491
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2492 /* Write each sibling byte and optionally extra info. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2493 for (np = node; np != NULL; np = np->wn_sibling)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2494 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2495 if (np->wn_byte == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2496 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2497 if (fd != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2498 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2499 /* For a NUL byte (end of word) instead of the byte itself
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2500 * we write the flag/region items. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2501 flags = np->wn_flags;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2502 if (regionmask != 0 && np->wn_region != regionmask)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2503 flags |= WF_REGION;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2504 if (flags == 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2505 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2506 /* word without flags or region */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2507 putc(BY_NOFLAGS, fd); /* <byte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2508 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2509 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2510 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2511 putc(BY_FLAGS, fd); /* <byte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2512 putc(flags, fd); /* <flags> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2513 if (flags & WF_REGION)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2514 putc(np->wn_region, fd); /* <regionmask> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2515 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2516 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2517 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2518 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2519 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2520 if (np->wn_child->wn_index != 0 && np->wn_child->wn_wnode != node)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2521 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2522 /* The child is written elsewhere, write the reference. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2523 if (fd != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2524 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2525 putc(BY_INDEX, fd); /* <byte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2526 /* <nodeidx> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2527 put_bytes(fd, (long_u)np->wn_child->wn_index, 3);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2528 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2529 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2530 else if (np->wn_child->wn_wnode == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2531 /* We will write the child below and give it an index. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2532 np->wn_child->wn_wnode = node;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2533
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2534 if (fd != NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2535 if (putc(np->wn_byte, fd) == EOF) /* <byte> or <xbyte> */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2536 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2537 EMSG(_(e_write));
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2538 return 0;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2539 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2540 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2541 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2542
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2543 /* 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
2544 * the count. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2545 newindex += siblingcount + 1;
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
2546
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2547 /* Recursively dump the children of each sibling. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2548 for (np = node; np != NULL; np = np->wn_sibling)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2549 if (np->wn_byte != 0 && np->wn_child->wn_wnode == node)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2550 newindex = put_tree(fd, np->wn_child, newindex, regionmask);
249
f146656fb903 updated for version 7.0069
vimboss
parents: 243
diff changeset
2551
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2552 return newindex;
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2553 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2554
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2555
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2556 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2557 * ":mkspell outfile infile ..."
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2558 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2559 void
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2560 ex_mkspell(eap)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2561 exarg_T *eap;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2562 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2563 int fcount;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2564 char_u **fnames;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2565 char_u fname[MAXPATHL];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2566 char_u wfname[MAXPATHL];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2567 afffile_T *(afile[8]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2568 int i;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2569 int len;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2570 char_u region_name[16];
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2571 struct stat st;
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2572 char_u *arg = eap->arg;
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2573 int error = FALSE;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2574 spellinfo_T spin;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2575
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2576 vim_memset(&spin, 0, sizeof(spin));
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2577
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2578 if (STRNCMP(arg, "-ascii", 6) == 0)
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2579 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2580 spin.si_ascii = TRUE;
240
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2581 arg = skipwhite(arg + 6);
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2582 }
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2583
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2584 /* Expand all the remaining arguments (e.g., $VIMRUNTIME). */
693800033ceb updated for version 7.0067
vimboss
parents: 236
diff changeset
2585 if (get_arglist_exp(arg, &fcount, &fnames) == FAIL)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2586 return;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2587 if (fcount < 2)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2588 EMSG(_(e_invarg)); /* need at least output and input names */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2589 else if (fcount > 9)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2590 EMSG(_("E754: Only up to 8 regions supported"));
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2591 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2592 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2593 /* Check for overwriting before doing things that may take a lot of
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2594 * time. */
272
ddada568db54 updated for version 7.0073
vimboss
parents: 260
diff changeset
2595 vim_snprintf((char *)wfname, sizeof(wfname), "%s.%s.spl", fnames[0],
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2596 spin.si_ascii ? (char_u *)"ascii" : p_enc);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2597 if (!eap->forceit && mch_stat((char *)wfname, &st) >= 0)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2598 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2599 EMSG(_(e_exists));
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2600 goto theend;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2601 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2602 if (mch_isdir(fnames[0]))
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2603 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2604 EMSG2(_(e_isadir2), fnames[0]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2605 goto theend;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2606 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2607
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2608 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2609 * Init the aff and dic pointers.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2610 * Get the region names if there are more than 2 arguments.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2611 */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2612 for (i = 1; i < fcount; ++i)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2613 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2614 afile[i - 1] = NULL;
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2615
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2616 if (fcount > 2)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2617 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2618 len = STRLEN(fnames[i]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2619 if (STRLEN(gettail(fnames[i])) < 5 || fnames[i][len - 3] != '_')
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2620 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2621 EMSG2(_("E755: Invalid region in %s"), fnames[i]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2622 goto theend;
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2623 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2624 else
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2625 {
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2626 region_name[(i - 1) * 2] = TOLOWER_ASC(fnames[i][len - 2]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2627 region_name[(i - 1) * 2 + 1] =
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2628 TOLOWER_ASC(fnames[i][len - 1]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2629 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2630 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2631 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2632
255
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2633 /* 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
2634 * used spell properties. */
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2635 init_spell_chartab();
c8742c8da9ab updated for version 7.0070
vimboss
parents: 249
diff changeset
2636
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2637 spin.si_foldroot = wordtree_alloc(&spin.si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2638 spin.si_keeproot = wordtree_alloc(&spin.si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2639 if (spin.si_foldroot == NULL || spin.si_keeproot == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2640 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2641 error = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2642 goto theend;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2643 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2644
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2645 /*
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2646 * Read all the .aff and .dic files.
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2647 * Text is converted to 'encoding'.
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2648 * Words are stored in the case-folded and keep-case trees.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2649 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2650 for (i = 1; i < fcount && !error; ++i)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2651 {
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2652 spin.si_conv.vc_type = CONV_NONE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2653 spin.si_region = 1 << (i - 1);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2654
272
ddada568db54 updated for version 7.0073
vimboss
parents: 260
diff changeset
2655 vim_snprintf((char *)fname, sizeof(fname), "%s.aff", fnames[i]);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2656 if (mch_stat((char *)fname, &st) >= 0)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2657 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2658 /* Read the .aff file. Will init "spin->si_conv" based on the
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2659 * "SET" line. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2660 afile[i - 1] = spell_read_aff(fname, &spin);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2661 if (afile[i - 1] == NULL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2662 error = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2663 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2664 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2665 /* Read the .dic file and store the words in the trees. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2666 vim_snprintf((char *)fname, sizeof(fname), "%s.dic",
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2667 fnames[i]);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2668 if (spell_read_dic(fname, &spin, afile[i - 1]) == 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 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2671 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2672 else
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2673 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2674 /* No .aff file, try reading the file as a word list. Store
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2675 * the words in the trees. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2676 if (spell_read_wordfile(fnames[i], &spin) == FAIL)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2677 error = TRUE;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2678 }
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2679
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2680 /* Free any conversion stuff. */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2681 convert_setup(&spin.si_conv, NULL, NULL);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2682 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2683
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2684 if (!error)
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2685 {
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 * Remove the dummy NUL from the start of the tree root.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2688 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2689 spin.si_foldroot = spin.si_foldroot->wn_sibling;
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2690 spin.si_keeproot = spin.si_keeproot->wn_sibling;
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 * Combine tails in the tree.
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2694 */
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2695 MSG(_("Compressing word tree..."));
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2696 out_flush();
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2697 wordtree_compress(spin.si_foldroot);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2698 wordtree_compress(spin.si_keeproot);
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2699 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2700
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2701 if (!error)
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2702 {
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2703 /*
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2704 * Write the info in the spell file.
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2705 */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2706 smsg((char_u *)_("Writing spell file %s..."), wfname);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2707 out_flush();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2708 write_vim_spell(wfname, &spin, fcount - 1, region_name);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2709 MSG(_("Done!"));
302
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
2710
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
2711 smsg((char_u *)_("Estimated runtime memory use: %d bytes"),
250611b3068d updated for version 7.0080
vimboss
parents: 300
diff changeset
2712 spin.si_memtot);
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2713 out_flush();
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2714 }
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2715
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2716 /* Free the allocated memory. */
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2717 free_blocks(spin.si_blocks);
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2718
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2719 /* Free the .aff file structures. */
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2720 for (i = 1; i < fcount; ++i)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2721 if (afile[i - 1] != NULL)
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2722 spell_free_aff(afile[i - 1]);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2723 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2724
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2725 theend:
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2726 FreeWild(fcount, fnames);
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2727 }
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2728
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2729 #endif /* FEAT_MBYTE */
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2730
300
86cd0a77d2ae updated for version 7.0079
vimboss
parents: 290
diff changeset
2731
236
4707450c2b33 updated for version 7.0066
vimboss
parents: 233
diff changeset
2732 #endif /* FEAT_SYN_HL */