Mercurial > vim
comparison runtime/autoload/csscomplete.vim @ 1121:e63691e7c504
updated for version 7.1a
author | vimboss |
---|---|
date | Sat, 05 May 2007 17:54:07 +0000 |
parents | 8cd729851562 |
children | 2bf08b6fa352 |
comparison
equal
deleted
inserted
replaced
1120:e6db096b07a1 | 1121:e63691e7c504 |
---|---|
1 " Vim completion script | 1 " Vim completion script |
2 " Language: CSS 2.1 | 2 " Language: CSS 2.1 |
3 " Maintainer: Mikolaj Machowski ( mikmach AT wp DOT pl ) | 3 " Maintainer: Mikolaj Machowski ( mikmach AT wp DOT pl ) |
4 " Last Change: 2006 Apr 30 | 4 " Last Change: 2007 Mar 11 |
5 | 5 |
6 function! csscomplete#CompleteCSS(findstart, base) | 6 function! csscomplete#CompleteCSS(findstart, base) |
7 | |
7 if a:findstart | 8 if a:findstart |
8 " We need whole line to proper checking | 9 " We need whole line to proper checking |
9 let line = getline('.') | 10 let line = getline('.') |
10 let start = col('.') - 1 | 11 let start = col('.') - 1 |
11 let compl_begin = col('.') - 2 | 12 let compl_begin = col('.') - 2 |
12 while start >= 0 && line[start - 1] =~ '\(\k\|-\)' | 13 while start >= 0 && line[start - 1] =~ '\%(\k\|-\)' |
13 let start -= 1 | 14 let start -= 1 |
14 endwhile | 15 endwhile |
15 let b:compl_context = getline('.')[0:compl_begin] | 16 let b:compl_context = getline('.')[0:compl_begin] |
16 return start | 17 return start |
18 endif | |
19 | |
20 " There are few chars important for context: | |
21 " ^ ; : { } /* */ | |
22 " Where ^ is start of line and /* */ are comment borders | |
23 " Depending on their relative position to cursor we will know what should | |
24 " be completed. | |
25 " 1. if nearest are ^ or { or ; current word is property | |
26 " 2. if : it is value (with exception of pseudo things) | |
27 " 3. if } we are outside of css definitions | |
28 " 4. for comments ignoring is be the easiest but assume they are the same | |
29 " as 1. | |
30 " 5. if @ complete at-rule | |
31 " 6. if ! complete important | |
32 if exists("b:compl_context") | |
33 let line = b:compl_context | |
34 unlet! b:compl_context | |
17 else | 35 else |
18 " There are few chars important for context: | 36 let line = a:base |
19 " ^ ; : { } /* */ | 37 endif |
20 " Where ^ is start of line and /* */ are comment borders | 38 |
21 " Depending on their relative position to cursor we will now what should | 39 let res = [] |
22 " be completed. | 40 let res2 = [] |
23 " 1. if nearest are ^ or { or ; current word is property | 41 let borders = {} |
24 " 2. if : it is value (with exception of pseudo things) | 42 |
25 " 3. if } we are outside of css definitions | 43 " Check last occurrence of sequence |
26 " 4. for comments ignoring is be the easiest but assume they are the same | 44 |
27 " as 1. | 45 let openbrace = strridx(line, '{') |
28 " 5. if @ complete at-rule | 46 let closebrace = strridx(line, '}') |
29 " 6. if ! complete important | 47 let colon = strridx(line, ':') |
30 if exists("b:compl_context") | 48 let semicolon = strridx(line, ';') |
31 let line = b:compl_context | 49 let opencomm = strridx(line, '/*') |
32 unlet! b:compl_context | 50 let closecomm = strridx(line, '*/') |
51 let style = strridx(line, 'style\s*=') | |
52 let atrule = strridx(line, '@') | |
53 let exclam = strridx(line, '!') | |
54 | |
55 if openbrace > -1 | |
56 let borders[openbrace] = "openbrace" | |
57 endif | |
58 if closebrace > -1 | |
59 let borders[closebrace] = "closebrace" | |
60 endif | |
61 if colon > -1 | |
62 let borders[colon] = "colon" | |
63 endif | |
64 if semicolon > -1 | |
65 let borders[semicolon] = "semicolon" | |
66 endif | |
67 if opencomm > -1 | |
68 let borders[opencomm] = "opencomm" | |
69 endif | |
70 if closecomm > -1 | |
71 let borders[closecomm] = "closecomm" | |
72 endif | |
73 if style > -1 | |
74 let borders[style] = "style" | |
75 endif | |
76 if atrule > -1 | |
77 let borders[atrule] = "atrule" | |
78 endif | |
79 if exclam > -1 | |
80 let borders[exclam] = "exclam" | |
81 endif | |
82 | |
83 | |
84 if len(borders) == 0 || borders[max(keys(borders))] =~ '^\%(openbrace\|semicolon\|opencomm\|closecomm\|style\)$' | |
85 " Complete properties | |
86 | |
87 let values = split("azimuth background background-attachment background-color background-image background-position background-repeat border bottom border-collapse border-color border-spacing border-style border-top border-right border-bottom border-left border-top-color border-right-color border-bottom-color border-left-color border-top-style border-right-style border-bottom-style border-left-style border-top-width border-right-width border-bottom-width border-left-width border-width caption-side clear clip color content counter-increment counter-reset cue cue-after cue-before cursor display direction elevation empty-cells float font font-family font-size font-style font-variant font-weight height left letter-spacing line-height list-style list-style-image list-style-position list-style-type margin margin-right margin-left margin-top margin-bottom max-height max-width min-height min-width orphans outline outline-color outline-style outline-width overflow padding padding-top padding-right padding-bottom padding-left page-break-after page-break-before page-break-inside pause pause-after pause-before pitch pitch-range play-during position quotes right richness speak speak-header speak-numeral speak-punctuation speech-rate stress table-layout text-align text-decoration text-indent text-transform top unicode-bidi vertical-align visibility voice-family volume white-space width widows word-spacing z-index") | |
88 | |
89 let entered_property = matchstr(line, '.\{-}\zs[a-zA-Z-]*$') | |
90 | |
91 for m in values | |
92 if m =~? '^'.entered_property | |
93 call add(res, m . ':') | |
94 elseif m =~? entered_property | |
95 call add(res2, m . ':') | |
96 endif | |
97 endfor | |
98 | |
99 return res + res2 | |
100 | |
101 elseif borders[max(keys(borders))] == 'colon' | |
102 " Get name of property | |
103 let prop = tolower(matchstr(line, '\zs[a-zA-Z-]*\ze\s*:[^:]\{-}$')) | |
104 | |
105 if prop == 'azimuth' | |
106 let values = ["left-side", "far-left", "left", "center-left", "center", "center-right", "right", "far-right", "right-side", "behind", "leftwards", "rightwards"] | |
107 elseif prop == 'background-attachment' | |
108 let values = ["scroll", "fixed"] | |
109 elseif prop == 'background-color' | |
110 let values = ["transparent", "rgb(", "#"] | |
111 elseif prop == 'background-image' | |
112 let values = ["url(", "none"] | |
113 elseif prop == 'background-position' | |
114 let vals = matchstr(line, '.*:\s*\zs.*') | |
115 if vals =~ '^\%([a-zA-Z]\+\)\?$' | |
116 let values = ["top", "center", "bottom"] | |
117 elseif vals =~ '^[a-zA-Z]\+\s\+\%([a-zA-Z]\+\)\?$' | |
118 let values = ["left", "center", "right"] | |
119 else | |
120 return [] | |
121 endif | |
122 elseif prop == 'background-repeat' | |
123 let values = ["repeat", "repeat-x", "repeat-y", "no-repeat"] | |
124 elseif prop == 'background' | |
125 let values = ["url(", "scroll", "fixed", "transparent", "rgb(", "#", "none", "top", "center", "bottom" , "left", "right", "repeat", "repeat-x", "repeat-y", "no-repeat"] | |
126 elseif prop == 'border-collapse' | |
127 let values = ["collapse", "separate"] | |
128 elseif prop == 'border-color' | |
129 let values = ["rgb(", "#", "transparent"] | |
130 elseif prop == 'border-spacing' | |
131 return [] | |
132 elseif prop == 'border-style' | |
133 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
134 elseif prop =~ 'border-\%(top\|right\|bottom\|left\)$' | |
135 let vals = matchstr(line, '.*:\s*\zs.*') | |
136 if vals =~ '^\%([a-zA-Z0-9.]\+\)\?$' | |
137 let values = ["thin", "thick", "medium"] | |
138 elseif vals =~ '^[a-zA-Z0-9.]\+\s\+\%([a-zA-Z]\+\)\?$' | |
139 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
140 elseif vals =~ '^[a-zA-Z0-9.]\+\s\+[a-zA-Z]\+\s\+\%([a-zA-Z(]\+\)\?$' | |
141 let values = ["rgb(", "#", "transparent"] | |
142 else | |
143 return [] | |
144 endif | |
145 elseif prop =~ 'border-\%(top\|right\|bottom\|left\)-color' | |
146 let values = ["rgb(", "#", "transparent"] | |
147 elseif prop =~ 'border-\%(top\|right\|bottom\|left\)-style' | |
148 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
149 elseif prop =~ 'border-\%(top\|right\|bottom\|left\)-width' | |
150 let values = ["thin", "thick", "medium"] | |
151 elseif prop == 'border-width' | |
152 let values = ["thin", "thick", "medium"] | |
153 elseif prop == 'border' | |
154 let vals = matchstr(line, '.*:\s*\zs.*') | |
155 if vals =~ '^\%([a-zA-Z0-9.]\+\)\?$' | |
156 let values = ["thin", "thick", "medium"] | |
157 elseif vals =~ '^[a-zA-Z0-9.]\+\s\+\%([a-zA-Z]\+\)\?$' | |
158 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
159 elseif vals =~ '^[a-zA-Z0-9.]\+\s\+[a-zA-Z]\+\s\+\%([a-zA-Z(]\+\)\?$' | |
160 let values = ["rgb(", "#", "transparent"] | |
161 else | |
162 return [] | |
163 endif | |
164 elseif prop == 'bottom' | |
165 let values = ["auto"] | |
166 elseif prop == 'caption-side' | |
167 let values = ["top", "bottom"] | |
168 elseif prop == 'clear' | |
169 let values = ["none", "left", "right", "both"] | |
170 elseif prop == 'clip' | |
171 let values = ["auto", "rect("] | |
172 elseif prop == 'color' | |
173 let values = ["rgb(", "#"] | |
174 elseif prop == 'content' | |
175 let values = ["normal", "attr(", "open-quote", "close-quote", "no-open-quote", "no-close-quote"] | |
176 elseif prop =~ 'counter-\%(increment\|reset\)$' | |
177 let values = ["none"] | |
178 elseif prop =~ '^\%(cue-after\|cue-before\|cue\)$' | |
179 let values = ["url(", "none"] | |
180 elseif prop == 'cursor' | |
181 let values = ["url(", "auto", "crosshair", "default", "pointer", "move", "e-resize", "ne-resize", "nw-resize", "n-resize", "se-resize", "sw-resize", "s-resize", "w-resize", "text", "wait", "help", "progress"] | |
182 elseif prop == 'direction' | |
183 let values = ["ltr", "rtl"] | |
184 elseif prop == 'display' | |
185 let values = ["inline", "block", "list-item", "run-in", "inline-block", "table", "inline-table", "table-row-group", "table-header-group", "table-footer-group", "table-row", "table-column-group", "table-column", "table-cell", "table-caption", "none"] | |
186 elseif prop == 'elevation' | |
187 let values = ["below", "level", "above", "higher", "lower"] | |
188 elseif prop == 'empty-cells' | |
189 let values = ["show", "hide"] | |
190 elseif prop == 'float' | |
191 let values = ["left", "right", "none"] | |
192 elseif prop == 'font-family' | |
193 let values = ["sans-serif", "serif", "monospace", "cursive", "fantasy"] | |
194 elseif prop == 'font-size' | |
195 let values = ["xx-small", "x-small", "small", "medium", "large", "x-large", "xx-large", "larger", "smaller"] | |
196 elseif prop == 'font-style' | |
197 let values = ["normal", "italic", "oblique"] | |
198 elseif prop == 'font-variant' | |
199 let values = ["normal", "small-caps"] | |
200 elseif prop == 'font-weight' | |
201 let values = ["normal", "bold", "bolder", "lighter", "100", "200", "300", "400", "500", "600", "700", "800", "900"] | |
202 elseif prop == 'font' | |
203 let values = ["normal", "italic", "oblique", "small-caps", "bold", "bolder", "lighter", "100", "200", "300", "400", "500", "600", "700", "800", "900", "xx-small", "x-small", "small", "medium", "large", "x-large", "xx-large", "larger", "smaller", "sans-serif", "serif", "monospace", "cursive", "fantasy", "caption", "icon", "menu", "message-box", "small-caption", "status-bar"] | |
204 elseif prop =~ '^\%(height\|width\)$' | |
205 let values = ["auto"] | |
206 elseif prop =~ '^\%(left\|rigth\)$' | |
207 let values = ["auto"] | |
208 elseif prop == 'letter-spacing' | |
209 let values = ["normal"] | |
210 elseif prop == 'line-height' | |
211 let values = ["normal"] | |
212 elseif prop == 'list-style-image' | |
213 let values = ["url(", "none"] | |
214 elseif prop == 'list-style-position' | |
215 let values = ["inside", "outside"] | |
216 elseif prop == 'list-style-type' | |
217 let values = ["disc", "circle", "square", "decimal", "decimal-leading-zero", "lower-roman", "upper-roman", "lower-latin", "upper-latin", "none"] | |
218 elseif prop == 'list-style' | |
219 return [] | |
220 elseif prop == 'margin' | |
221 let values = ["auto"] | |
222 elseif prop =~ 'margin-\%(right\|left\|top\|bottom\)$' | |
223 let values = ["auto"] | |
224 elseif prop == 'max-height' | |
225 let values = ["auto"] | |
226 elseif prop == 'max-width' | |
227 let values = ["none"] | |
228 elseif prop == 'min-height' | |
229 let values = ["none"] | |
230 elseif prop == 'min-width' | |
231 let values = ["none"] | |
232 elseif prop == 'orphans' | |
233 return [] | |
234 elseif prop == 'outline-color' | |
235 let values = ["rgb(", "#"] | |
236 elseif prop == 'outline-style' | |
237 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
238 elseif prop == 'outline-width' | |
239 let values = ["thin", "thick", "medium"] | |
240 elseif prop == 'outline' | |
241 let vals = matchstr(line, '.*:\s*\zs.*') | |
242 if vals =~ '^\%([a-zA-Z0-9,()#]\+\)\?$' | |
243 let values = ["rgb(", "#"] | |
244 elseif vals =~ '^[a-zA-Z0-9,()#]\+\s\+\%([a-zA-Z]\+\)\?$' | |
245 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
246 elseif vals =~ '^[a-zA-Z0-9,()#]\+\s\+[a-zA-Z]\+\s\+\%([a-zA-Z(]\+\)\?$' | |
247 let values = ["thin", "thick", "medium"] | |
248 else | |
249 return [] | |
250 endif | |
251 elseif prop == 'overflow' | |
252 let values = ["visible", "hidden", "scroll", "auto"] | |
253 elseif prop == 'padding' | |
254 return [] | |
255 elseif prop =~ 'padding-\%(top\|right\|bottom\|left\)$' | |
256 return [] | |
257 elseif prop =~ 'page-break-\%(after\|before\)$' | |
258 let values = ["auto", "always", "avoid", "left", "right"] | |
259 elseif prop == 'page-break-inside' | |
260 let values = ["auto", "avoid"] | |
261 elseif prop =~ 'pause-\%(after\|before\)$' | |
262 return [] | |
263 elseif prop == 'pause' | |
264 return [] | |
265 elseif prop == 'pitch-range' | |
266 return [] | |
267 elseif prop == 'pitch' | |
268 let values = ["x-low", "low", "medium", "high", "x-high"] | |
269 elseif prop == 'play-during' | |
270 let values = ["url(", "mix", "repeat", "auto", "none"] | |
271 elseif prop == 'position' | |
272 let values = ["static", "relative", "absolute", "fixed"] | |
273 elseif prop == 'quotes' | |
274 let values = ["none"] | |
275 elseif prop == 'richness' | |
276 return [] | |
277 elseif prop == 'speak-header' | |
278 let values = ["once", "always"] | |
279 elseif prop == 'speak-numeral' | |
280 let values = ["digits", "continuous"] | |
281 elseif prop == 'speak-punctuation' | |
282 let values = ["code", "none"] | |
283 elseif prop == 'speak' | |
284 let values = ["normal", "none", "spell-out"] | |
285 elseif prop == 'speech-rate' | |
286 let values = ["x-slow", "slow", "medium", "fast", "x-fast", "faster", "slower"] | |
287 elseif prop == 'stress' | |
288 return [] | |
289 elseif prop == 'table-layout' | |
290 let values = ["auto", "fixed"] | |
291 elseif prop == 'text-align' | |
292 let values = ["left", "right", "center", "justify"] | |
293 elseif prop == 'text-decoration' | |
294 let values = ["none", "underline", "overline", "line-through", "blink"] | |
295 elseif prop == 'text-indent' | |
296 return [] | |
297 elseif prop == 'text-transform' | |
298 let values = ["capitalize", "uppercase", "lowercase", "none"] | |
299 elseif prop == 'top' | |
300 let values = ["auto"] | |
301 elseif prop == 'unicode-bidi' | |
302 let values = ["normal", "embed", "bidi-override"] | |
303 elseif prop == 'vertical-align' | |
304 let values = ["baseline", "sub", "super", "top", "text-top", "middle", "bottom", "text-bottom"] | |
305 elseif prop == 'visibility' | |
306 let values = ["visible", "hidden", "collapse"] | |
307 elseif prop == 'voice-family' | |
308 return [] | |
309 elseif prop == 'volume' | |
310 let values = ["silent", "x-soft", "soft", "medium", "loud", "x-loud"] | |
311 elseif prop == 'white-space' | |
312 let values = ["normal", "pre", "nowrap", "pre-wrap", "pre-line"] | |
313 elseif prop == 'widows' | |
314 return [] | |
315 elseif prop == 'word-spacing' | |
316 let values = ["normal"] | |
317 elseif prop == 'z-index' | |
318 let values = ["auto"] | |
33 else | 319 else |
34 let line = a:base | 320 " If no property match it is possible we are outside of {} and |
321 " trying to complete pseudo-(class|element) | |
322 let element = tolower(matchstr(line, '\zs[a-zA-Z1-6]*\ze:[^:[:space:]]\{-}$')) | |
323 if stridx(',a,abbr,acronym,address,area,b,base,bdo,big,blockquote,body,br,button,caption,cite,code,col,colgroup,dd,del,dfn,div,dl,dt,em,fieldset,form,head,h1,h2,h3,h4,h5,h6,hr,html,i,img,input,ins,kbd,label,legend,li,link,map,meta,noscript,object,ol,optgroup,option,p,param,pre,q,samp,script,select,small,span,strong,style,sub,sup,table,tbody,td,textarea,tfoot,th,thead,title,tr,tt,ul,var,', ','.element.',') > -1 | |
324 let values = ["first-child", "link", "visited", "hover", "active", "focus", "lang", "first-line", "first-letter", "before", "after"] | |
325 else | |
326 return [] | |
327 endif | |
35 endif | 328 endif |
36 | 329 |
37 let res = [] | 330 " Complete values |
38 let res2 = [] | 331 let entered_value = matchstr(line, '.\{-}\zs[a-zA-Z0-9#,.(_-]*$') |
39 let borders = {} | 332 |
40 | 333 for m in values |
41 " We need the last occurrence of char so reverse line | 334 if m =~? '^'.entered_value |
42 let revline = join(reverse(split(line, '.\zs')), '') | 335 call add(res, m) |
43 | 336 elseif m =~? entered_value |
44 let openbrace = stridx(revline, '{') | 337 call add(res2, m) |
45 let closebrace = stridx(revline, '}') | 338 endif |
46 let colon = stridx(revline, ':') | 339 endfor |
47 let semicolon = stridx(revline, ';') | 340 |
48 let opencomm = stridx(revline, '*/') " Line was reversed | 341 return res + res2 |
49 let closecomm = stridx(revline, '/*') " Line was reversed | 342 |
50 let style = stridx(revline, '=\s*elyts') " Line was reversed | 343 elseif borders[max(keys(borders))] == 'closebrace' |
51 let atrule = stridx(revline, '@') | 344 |
52 let exclam = stridx(revline, '!') | 345 return [] |
53 | 346 |
54 if openbrace > -1 | 347 elseif borders[max(keys(borders))] == 'exclam' |
55 let borders[openbrace] = "openbrace" | 348 |
56 endif | 349 " Complete values |
57 if closebrace > -1 | 350 let entered_imp = matchstr(line, '.\{-}!\s*\zs[a-zA-Z ]*$') |
58 let borders[closebrace] = "closebrace" | 351 |
59 endif | 352 let values = ["important"] |
60 if colon > -1 | 353 |
61 let borders[colon] = "colon" | 354 for m in values |
62 endif | 355 if m =~? '^'.entered_imp |
63 if semicolon > -1 | 356 call add(res, m) |
64 let borders[semicolon] = "semicolon" | 357 endif |
65 endif | 358 endfor |
66 if opencomm > -1 | 359 |
67 let borders[opencomm] = "opencomm" | 360 return res |
68 endif | 361 |
69 if closecomm > -1 | 362 elseif borders[max(keys(borders))] == 'atrule' |
70 let borders[closecomm] = "closecomm" | 363 |
71 endif | 364 let afterat = matchstr(line, '.*@\zs.*') |
72 if style > -1 | 365 |
73 let borders[style] = "style" | 366 if afterat =~ '\s' |
74 endif | 367 |
75 if atrule > -1 | 368 let atrulename = matchstr(line, '.*@\zs[a-zA-Z-]\+\ze') |
76 let borders[atrule] = "atrule" | 369 |
77 endif | 370 if atrulename == 'media' |
78 if exclam > -1 | 371 let values = ["screen", "tty", "tv", "projection", "handheld", "print", "braille", "aural", "all"] |
79 let borders[exclam] = "exclam" | 372 |
80 endif | 373 let atruleafterbase = matchstr(line, '.*@media\s\+\ze.*$') |
81 | 374 let entered_atruleafter = matchstr(line, '.*@media\s\+\zs.*$') |
82 | 375 |
83 if len(borders) == 0 || borders[min(keys(borders))] =~ '^\(openbrace\|semicolon\|opencomm\|closecomm\|style\)$' | 376 elseif atrulename == 'import' |
84 " Complete properties | 377 let atruleafterbase = matchstr(line, '.*@import\s\+\ze.*$') |
85 | 378 let entered_atruleafter = matchstr(line, '.*@import\s\+\zs.*$') |
86 let values = split("azimuth background background-attachment background-color background-image background-position background-repeat border bottom border-collapse border-color border-spacing border-style border-top border-right border-bottom border-left border-top-color border-right-color border-bottom-color border-left-color border-top-style border-right-style border-bottom-style border-left-style border-top-width border-right-width border-bottom-width border-left-width border-width caption-side clear clip color content counter-increment counter-reset cue cue-after cue-before cursor display direction elevation empty-cells float font font-family font-size font-style font-variant font-weight height left letter-spacing line-height list-style list-style-image list-style-position list-style-type margin margin-right margin-left margin-top margin-bottom max-height max-width min-height min-width orphans outline outline-color outline-style outline-width overflow padding padding-top padding-right padding-bottom padding-left page-break-after page-break-before page-break-inside pause pause-after pause-before pitch pitch-range play-during position quotes right richness speak speak-header speak-numeral speak-punctuation speech-rate stress table-layout text-align text-decoration text-indent text-transform top unicode-bidi vertical-align visibility voice-family volume white-space width widows word-spacing z-index") | 379 |
87 | 380 if entered_atruleafter =~ "^[\"']" |
88 let entered_property = matchstr(line, '.\{-}\zs[a-zA-Z-]*$') | 381 let filestart = matchstr(entered_atruleafter, '^.\zs.*') |
382 let files = split(glob(filestart.'*'), '\n') | |
383 let values = map(copy(files), '"\"".v:val') | |
384 | |
385 elseif entered_atruleafter =~ "^url(" | |
386 let filestart = matchstr(entered_atruleafter, "^url([\"']\\?\\zs.*") | |
387 let files = split(glob(filestart.'*'), '\n') | |
388 let values = map(copy(files), '"url(".v:val') | |
389 | |
390 else | |
391 let values = ['"', 'url('] | |
392 | |
393 endif | |
394 | |
395 else | |
396 return [] | |
397 | |
398 endif | |
89 | 399 |
90 for m in values | 400 for m in values |
91 if m =~? '^'.entered_property | 401 if m =~? '^'.entered_atruleafter |
92 call add(res, m . ':') | |
93 elseif m =~? entered_property | |
94 call add(res2, m . ':') | |
95 endif | |
96 endfor | |
97 | |
98 return res + res2 | |
99 | |
100 elseif borders[min(keys(borders))] == 'colon' | |
101 " Get name of property | |
102 let prop = tolower(matchstr(line, '\zs[a-zA-Z-]*\ze\s*:[^:]\{-}$')) | |
103 | |
104 if prop == 'azimuth' | |
105 let values = ["left-side", "far-left", "left", "center-left", "center", "center-right", "right", "far-right", "right-side", "behind", "leftwards", "rightwards"] | |
106 elseif prop == 'background-attachment' | |
107 let values = ["scroll", "fixed"] | |
108 elseif prop == 'background-color' | |
109 let values = ["transparent", "rgb(", "#"] | |
110 elseif prop == 'background-image' | |
111 let values = ["url(", "none"] | |
112 elseif prop == 'background-position' | |
113 let vals = matchstr(line, '.*:\s*\zs.*') | |
114 if vals =~ '^\([a-zA-Z]\+\)\?$' | |
115 let values = ["top", "center", "bottom"] | |
116 elseif vals =~ '^[a-zA-Z]\+\s\+\([a-zA-Z]\+\)\?$' | |
117 let values = ["left", "center", "right"] | |
118 else | |
119 return [] | |
120 endif | |
121 elseif prop == 'background-repeat' | |
122 let values = ["repeat", "repeat-x", "repeat-y", "no-repeat"] | |
123 elseif prop == 'background' | |
124 let values = ["url(", "scroll", "fixed", "transparent", "rgb(", "#", "none", "top", "center", "bottom" , "left", "right", "repeat", "repeat-x", "repeat-y", "no-repeat"] | |
125 elseif prop == 'border-collapse' | |
126 let values = ["collapse", "separate"] | |
127 elseif prop == 'border-color' | |
128 let values = ["rgb(", "#", "transparent"] | |
129 elseif prop == 'border-spacing' | |
130 return [] | |
131 elseif prop == 'border-style' | |
132 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
133 elseif prop =~ 'border-\(top\|right\|bottom\|left\)$' | |
134 let vals = matchstr(line, '.*:\s*\zs.*') | |
135 if vals =~ '^\([a-zA-Z0-9.]\+\)\?$' | |
136 let values = ["thin", "thick", "medium"] | |
137 elseif vals =~ '^[a-zA-Z0-9.]\+\s\+\([a-zA-Z]\+\)\?$' | |
138 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
139 elseif vals =~ '^[a-zA-Z0-9.]\+\s\+[a-zA-Z]\+\s\+\([a-zA-Z(]\+\)\?$' | |
140 let values = ["rgb(", "#", "transparent"] | |
141 else | |
142 return [] | |
143 endif | |
144 elseif prop =~ 'border-\(top\|right\|bottom\|left\)-color' | |
145 let values = ["rgb(", "#", "transparent"] | |
146 elseif prop =~ 'border-\(top\|right\|bottom\|left\)-style' | |
147 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
148 elseif prop =~ 'border-\(top\|right\|bottom\|left\)-width' | |
149 let values = ["thin", "thick", "medium"] | |
150 elseif prop == 'border-width' | |
151 let values = ["thin", "thick", "medium"] | |
152 elseif prop == 'border' | |
153 let vals = matchstr(line, '.*:\s*\zs.*') | |
154 if vals =~ '^\([a-zA-Z0-9.]\+\)\?$' | |
155 let values = ["thin", "thick", "medium"] | |
156 elseif vals =~ '^[a-zA-Z0-9.]\+\s\+\([a-zA-Z]\+\)\?$' | |
157 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
158 elseif vals =~ '^[a-zA-Z0-9.]\+\s\+[a-zA-Z]\+\s\+\([a-zA-Z(]\+\)\?$' | |
159 let values = ["rgb(", "#", "transparent"] | |
160 else | |
161 return [] | |
162 endif | |
163 elseif prop == 'bottom' | |
164 let values = ["auto"] | |
165 elseif prop == 'caption-side' | |
166 let values = ["top", "bottom"] | |
167 elseif prop == 'clear' | |
168 let values = ["none", "left", "right", "both"] | |
169 elseif prop == 'clip' | |
170 let values = ["auto", "rect("] | |
171 elseif prop == 'color' | |
172 let values = ["rgb(", "#"] | |
173 elseif prop == 'content' | |
174 let values = ["normal", "attr(", "open-quote", "close-quote", "no-open-quote", "no-close-quote"] | |
175 elseif prop =~ 'counter-\(increment\|reset\)$' | |
176 let values = ["none"] | |
177 elseif prop =~ '^\(cue-after\|cue-before\|cue\)$' | |
178 let values = ["url(", "none"] | |
179 elseif prop == 'cursor' | |
180 let values = ["url(", "auto", "crosshair", "default", "pointer", "move", "e-resize", "ne-resize", "nw-resize", "n-resize", "se-resize", "sw-resize", "s-resize", "w-resize", "text", "wait", "help", "progress"] | |
181 elseif prop == 'direction' | |
182 let values = ["ltr", "rtl"] | |
183 elseif prop == 'display' | |
184 let values = ["inline", "block", "list-item", "run-in", "inline-block", "table", "inline-table", "table-row-group", "table-header-group", "table-footer-group", "table-row", "table-column-group", "table-column", "table-cell", "table-caption", "none"] | |
185 elseif prop == 'elevation' | |
186 let values = ["below", "level", "above", "higher", "lower"] | |
187 elseif prop == 'empty-cells' | |
188 let values = ["show", "hide"] | |
189 elseif prop == 'float' | |
190 let values = ["left", "right", "none"] | |
191 elseif prop == 'font-family' | |
192 let values = ["sans-serif", "serif", "monospace", "cursive", "fantasy"] | |
193 elseif prop == 'font-size' | |
194 let values = ["xx-small", "x-small", "small", "medium", "large", "x-large", "xx-large", "larger", "smaller"] | |
195 elseif prop == 'font-style' | |
196 let values = ["normal", "italic", "oblique"] | |
197 elseif prop == 'font-variant' | |
198 let values = ["normal", "small-caps"] | |
199 elseif prop == 'font-weight' | |
200 let values = ["normal", "bold", "bolder", "lighter", "100", "200", "300", "400", "500", "600", "700", "800", "900"] | |
201 elseif prop == 'font' | |
202 let values = ["normal", "italic", "oblique", "small-caps", "bold", "bolder", "lighter", "100", "200", "300", "400", "500", "600", "700", "800", "900", "xx-small", "x-small", "small", "medium", "large", "x-large", "xx-large", "larger", "smaller", "sans-serif", "serif", "monospace", "cursive", "fantasy", "caption", "icon", "menu", "message-box", "small-caption", "status-bar"] | |
203 elseif prop =~ '^\(height\|width\)$' | |
204 let values = ["auto"] | |
205 elseif prop =~ '^\(left\|rigth\)$' | |
206 let values = ["auto"] | |
207 elseif prop == 'letter-spacing' | |
208 let values = ["normal"] | |
209 elseif prop == 'line-height' | |
210 let values = ["normal"] | |
211 elseif prop == 'list-style-image' | |
212 let values = ["url(", "none"] | |
213 elseif prop == 'list-style-position' | |
214 let values = ["inside", "outside"] | |
215 elseif prop == 'list-style-type' | |
216 let values = ["disc", "circle", "square", "decimal", "decimal-leading-zero", "lower-roman", "upper-roman", "lower-latin", "upper-latin", "none"] | |
217 elseif prop == 'list-style' | |
218 return [] | |
219 elseif prop == 'margin' | |
220 let values = ["auto"] | |
221 elseif prop =~ 'margin-\(right\|left\|top\|bottom\)$' | |
222 let values = ["auto"] | |
223 elseif prop == 'max-height' | |
224 let values = ["auto"] | |
225 elseif prop == 'max-width' | |
226 let values = ["none"] | |
227 elseif prop == 'min-height' | |
228 let values = ["none"] | |
229 elseif prop == 'min-width' | |
230 let values = ["none"] | |
231 elseif prop == 'orphans' | |
232 return [] | |
233 elseif prop == 'outline-color' | |
234 let values = ["rgb(", "#"] | |
235 elseif prop == 'outline-style' | |
236 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
237 elseif prop == 'outline-width' | |
238 let values = ["thin", "thick", "medium"] | |
239 elseif prop == 'outline' | |
240 let vals = matchstr(line, '.*:\s*\zs.*') | |
241 if vals =~ '^\([a-zA-Z0-9,()#]\+\)\?$' | |
242 let values = ["rgb(", "#"] | |
243 elseif vals =~ '^[a-zA-Z0-9,()#]\+\s\+\([a-zA-Z]\+\)\?$' | |
244 let values = ["none", "hidden", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"] | |
245 elseif vals =~ '^[a-zA-Z0-9,()#]\+\s\+[a-zA-Z]\+\s\+\([a-zA-Z(]\+\)\?$' | |
246 let values = ["thin", "thick", "medium"] | |
247 else | |
248 return [] | |
249 endif | |
250 elseif prop == 'overflow' | |
251 let values = ["visible", "hidden", "scroll", "auto"] | |
252 elseif prop == 'padding' | |
253 return [] | |
254 elseif prop =~ 'padding-\(top\|right\|bottom\|left\)$' | |
255 return [] | |
256 elseif prop =~ 'page-break-\(after\|before\)$' | |
257 let values = ["auto", "always", "avoid", "left", "right"] | |
258 elseif prop == 'page-break-inside' | |
259 let values = ["auto", "avoid"] | |
260 elseif prop =~ 'pause-\(after\|before\)$' | |
261 return [] | |
262 elseif prop == 'pause' | |
263 return [] | |
264 elseif prop == 'pitch-range' | |
265 return [] | |
266 elseif prop == 'pitch' | |
267 let values = ["x-low", "low", "medium", "high", "x-high"] | |
268 elseif prop == 'play-during' | |
269 let values = ["url(", "mix", "repeat", "auto", "none"] | |
270 elseif prop == 'position' | |
271 let values = ["static", "relative", "absolute", "fixed"] | |
272 elseif prop == 'quotes' | |
273 let values = ["none"] | |
274 elseif prop == 'richness' | |
275 return [] | |
276 elseif prop == 'speak-header' | |
277 let values = ["once", "always"] | |
278 elseif prop == 'speak-numeral' | |
279 let values = ["digits", "continuous"] | |
280 elseif prop == 'speak-punctuation' | |
281 let values = ["code", "none"] | |
282 elseif prop == 'speak' | |
283 let values = ["normal", "none", "spell-out"] | |
284 elseif prop == 'speech-rate' | |
285 let values = ["x-slow", "slow", "medium", "fast", "x-fast", "faster", "slower"] | |
286 elseif prop == 'stress' | |
287 return [] | |
288 elseif prop == 'table-layout' | |
289 let values = ["auto", "fixed"] | |
290 elseif prop == 'text-align' | |
291 let values = ["left", "right", "center", "justify"] | |
292 elseif prop == 'text-decoration' | |
293 let values = ["none", "underline", "overline", "line-through", "blink"] | |
294 elseif prop == 'text-indent' | |
295 return [] | |
296 elseif prop == 'text-transform' | |
297 let values = ["capitalize", "uppercase", "lowercase", "none"] | |
298 elseif prop == 'top' | |
299 let values = ["auto"] | |
300 elseif prop == 'unicode-bidi' | |
301 let values = ["normal", "embed", "bidi-override"] | |
302 elseif prop == 'vertical-align' | |
303 let values = ["baseline", "sub", "super", "top", "text-top", "middle", "bottom", "text-bottom"] | |
304 elseif prop == 'visibility' | |
305 let values = ["visible", "hidden", "collapse"] | |
306 elseif prop == 'voice-family' | |
307 return [] | |
308 elseif prop == 'volume' | |
309 let values = ["silent", "x-soft", "soft", "medium", "loud", "x-loud"] | |
310 elseif prop == 'white-space' | |
311 let values = ["normal", "pre", "nowrap", "pre-wrap", "pre-line"] | |
312 elseif prop == 'widows' | |
313 return [] | |
314 elseif prop == 'word-spacing' | |
315 let values = ["normal"] | |
316 elseif prop == 'z-index' | |
317 let values = ["auto"] | |
318 else | |
319 " If no property match it is possible we are outside of {} and | |
320 " trying to complete pseudo-(class|element) | |
321 let element = tolower(matchstr(line, '\zs[a-zA-Z1-6]*\ze:[^:[:space:]]\{-}$')) | |
322 if ",a,abbr,acronym,address,area,b,base,bdo,big,blockquote,body,br,button,caption,cite,code,col,colgroup,dd,del,dfn,div,dl,dt,em,fieldset,form,head,h1,h2,h3,h4,h5,h6,hr,html,i,img,input,ins,kbd,label,legend,li,link,map,meta,noscript,object,ol,optgroup,option,p,param,pre,q,samp,script,select,small,span,strong,style,sub,sup,table,tbody,td,textarea,tfoot,th,thead,title,tr,tt,ul,var," =~ ','.element.',' | |
323 let values = ["first-child", "link", "visited", "hover", "active", "focus", "lang", "first-line", "first-letter", "before", "after"] | |
324 else | |
325 return [] | |
326 endif | |
327 endif | |
328 | |
329 " Complete values | |
330 let entered_value = matchstr(line, '.\{-}\zs[a-zA-Z0-9#,.(_-]*$') | |
331 | |
332 for m in values | |
333 if m =~? '^'.entered_value | |
334 call add(res, m) | 402 call add(res, m) |
335 elseif m =~? entered_value | 403 elseif m =~? entered_atruleafter |
336 call add(res2, m) | 404 call add(res2, m) |
337 endif | 405 endif |
338 endfor | 406 endfor |
339 | 407 |
340 return res + res2 | 408 return res + res2 |
341 | 409 |
342 elseif borders[min(keys(borders))] == 'closebrace' | |
343 | |
344 return [] | |
345 | |
346 elseif borders[min(keys(borders))] == 'exclam' | |
347 | |
348 " Complete values | |
349 let entered_imp = matchstr(line, '.\{-}!\s*\zs[a-zA-Z ]*$') | |
350 | |
351 let values = ["important"] | |
352 | |
353 for m in values | |
354 if m =~? '^'.entered_imp | |
355 call add(res, m) | |
356 endif | |
357 endfor | |
358 | |
359 return res | |
360 | |
361 elseif borders[min(keys(borders))] == 'atrule' | |
362 | |
363 let afterat = matchstr(line, '.*@\zs.*') | |
364 | |
365 if afterat =~ '\s' | |
366 | |
367 let atrulename = matchstr(line, '.*@\zs[a-zA-Z-]\+\ze') | |
368 | |
369 if atrulename == 'media' | |
370 let values = ["screen", "tty", "tv", "projection", "handheld", "print", "braille", "aural", "all"] | |
371 | |
372 let atruleafterbase = matchstr(line, '.*@media\s\+\ze.*$') | |
373 let entered_atruleafter = matchstr(line, '.*@media\s\+\zs.*$') | |
374 | |
375 elseif atrulename == 'import' | |
376 let atruleafterbase = matchstr(line, '.*@import\s\+\ze.*$') | |
377 let entered_atruleafter = matchstr(line, '.*@import\s\+\zs.*$') | |
378 | |
379 if entered_atruleafter =~ "^[\"']" | |
380 let filestart = matchstr(entered_atruleafter, '^.\zs.*') | |
381 let files = split(glob(filestart.'*'), '\n') | |
382 let values = map(copy(files), '"\"".v:val') | |
383 | |
384 elseif entered_atruleafter =~ "^url(" | |
385 let filestart = matchstr(entered_atruleafter, "^url([\"']\\?\\zs.*") | |
386 let files = split(glob(filestart.'*'), '\n') | |
387 let values = map(copy(files), '"url(".v:val') | |
388 | |
389 else | |
390 let values = ['"', 'url('] | |
391 | |
392 endif | |
393 | |
394 else | |
395 return [] | |
396 | |
397 endif | |
398 | |
399 for m in values | |
400 if m =~? '^'.entered_atruleafter | |
401 call add(res, m) | |
402 elseif m =~? entered_atruleafter | |
403 call add(res2, m) | |
404 endif | |
405 endfor | |
406 | |
407 return res + res2 | |
408 | |
409 endif | |
410 | |
411 let values = ["charset", "page", "media", "import", "font-face"] | |
412 | |
413 let entered_atrule = matchstr(line, '.*@\zs[a-zA-Z-]*$') | |
414 | |
415 for m in values | |
416 if m =~? '^'.entered_atrule | |
417 call add(res, m .' ') | |
418 elseif m =~? entered_atrule | |
419 call add(res2, m .' ') | |
420 endif | |
421 endfor | |
422 | |
423 return res + res2 | |
424 | |
425 endif | 410 endif |
426 | 411 |
427 return [] | 412 let values = ["charset", "page", "media", "import", "font-face"] |
428 | 413 |
429 endif | 414 let entered_atrule = matchstr(line, '.*@\zs[a-zA-Z-]*$') |
415 | |
416 for m in values | |
417 if m =~? '^'.entered_atrule | |
418 call add(res, m .' ') | |
419 elseif m =~? entered_atrule | |
420 call add(res2, m .' ') | |
421 endif | |
422 endfor | |
423 | |
424 return res + res2 | |
425 | |
426 endif | |
427 | |
428 return [] | |
429 | |
430 endfunction | 430 endfunction |