annotate src/spell.c @ 307:7010607c5753

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