Mercurial > vim
annotate runtime/filetype.vim @ 2202:f7579a31705c vim73
Updated runtime files.
author | Bram Moolenaar <bram@vim.org> |
---|---|
date | Fri, 21 May 2010 12:05:36 +0200 |
parents | b9e314fe473f |
children | 03a5f2897db3 |
rev | line source |
---|---|
7 | 1 " Vim support file to detect file types |
2 " | |
3 " Maintainer: Bram Moolenaar <Bram@vim.org> | |
2152 | 4 " Last Change: 2010 May 14 |
7 | 5 |
6 " Listen very carefully, I will say this only once | |
7 if exists("did_load_filetypes") | |
8 finish | |
9 endif | |
10 let did_load_filetypes = 1 | |
11 | |
12 " Line continuation is used here, remove 'C' from 'cpoptions' | |
13 let s:cpo_save = &cpo | |
14 set cpo&vim | |
15 | |
16 augroup filetypedetect | |
17 | |
18 " Ignored extensions | |
1586 | 19 if exists("*fnameescape") |
1668 | 20 au BufNewFile,BufRead ?\+.orig,?\+.bak,?\+.old,?\+.new,?\+.dpkg-dist,?\+.dpkg-old,?\+.rpmsave,?\+.rpmnew |
1586 | 21 \ exe "doau filetypedetect BufRead " . fnameescape(expand("<afile>:r")) |
7 | 22 au BufNewFile,BufRead *~ |
23 \ let s:name = expand("<afile>") | | |
24 \ let s:short = substitute(s:name, '\~$', '', '') | | |
25 \ if s:name != s:short && s:short != "" | | |
1586 | 26 \ exe "doau filetypedetect BufRead " . fnameescape(s:short) | |
7 | 27 \ endif | |
1698 | 28 \ unlet! s:name s:short |
532 | 29 au BufNewFile,BufRead ?\+.in |
7 | 30 \ if expand("<afile>:t") != "configure.in" | |
1586 | 31 \ exe "doau filetypedetect BufRead " . fnameescape(expand("<afile>:r")) | |
7 | 32 \ endif |
1586 | 33 elseif &verbose > 0 |
34 echomsg "Warning: some filetypes will not be recognized because this version of Vim does not have fnameescape()" | |
35 endif | |
7 | 36 |
37 " Pattern used to match file names which should not be inspected. | |
38 " Currently finds compressed files. | |
39 if !exists("g:ft_ignore_pat") | |
40 let g:ft_ignore_pat = '\.\(Z\|gz\|bz2\|zip\|tgz\)$' | |
41 endif | |
42 | |
216 | 43 " Function used for patterns that end in a star: don't set the filetype if the |
44 " file name matches ft_ignore_pat. | |
1219 | 45 func! s:StarSetf(ft) |
216 | 46 if expand("<amatch>") !~ g:ft_ignore_pat |
47 exe 'setf ' . a:ft | |
48 endif | |
1219 | 49 endfunc |
216 | 50 |
7 | 51 " Abaqus or Trasys |
216 | 52 au BufNewFile,BufRead *.inp call s:Check_inp() |
7 | 53 |
1219 | 54 func! s:Check_inp() |
7 | 55 if getline(1) =~ '^\*' |
56 setf abaqus | |
57 else | |
58 let n = 1 | |
59 if line("$") > 500 | |
60 let nmax = 500 | |
61 else | |
62 let nmax = line("$") | |
63 endif | |
64 while n <= nmax | |
65 if getline(n) =~? "^header surface data" | |
66 setf trasys | |
67 break | |
68 endif | |
69 let n = n + 1 | |
70 endwhile | |
71 endif | |
1219 | 72 endfunc |
7 | 73 |
74 " A-A-P recipe | |
75 au BufNewFile,BufRead *.aap setf aap | |
76 | |
389 | 77 " A2ps printing utility |
78 au BufNewFile,BufRead etc/a2ps.cfg,etc/a2ps/*.cfg,a2psrc,.a2psrc setf a2ps | |
79 | |
22 | 80 " ABAB/4 |
81 au BufNewFile,BufRead *.abap setf abap | |
82 | |
7 | 83 " ABC music notation |
84 au BufNewFile,BufRead *.abc setf abc | |
85 | |
86 " ABEL | |
87 au BufNewFile,BufRead *.abl setf abel | |
88 | |
89 " AceDB | |
90 au BufNewFile,BufRead *.wrm setf acedb | |
91 | |
92 " Ada (83, 9X, 95) | |
93 au BufNewFile,BufRead *.adb,*.ads,*.ada setf ada | |
1125 | 94 if has("vms") |
1676 | 95 au BufNewFile,BufRead *.gpr,*.ada_m,*.adc setf ada |
1125 | 96 else |
1676 | 97 au BufNewFile,BufRead *.gpr setf ada |
1125 | 98 endif |
7 | 99 |
100 " AHDL | |
101 au BufNewFile,BufRead *.tdf setf ahdl | |
102 | |
103 " AMPL | |
104 au BufNewFile,BufRead *.run setf ampl | |
105 | |
106 " Ant | |
107 au BufNewFile,BufRead build.xml setf ant | |
108 | |
109 " Apache style config file | |
216 | 110 au BufNewFile,BufRead proftpd.conf* call s:StarSetf('apachestyle') |
7 | 111 |
112 " Apache config file | |
2034 | 113 au BufNewFile,BufRead .htaccess,/etc/httpd/*.conf setf apache |
114 au BufNewFile,BufRead httpd.conf*,srm.conf*,access.conf*,apache.conf*,apache2.conf*,/etc/apache2/*.conf*,/etc/httpd/conf.d/*.conf* call s:StarSetf('apache') | |
7 | 115 |
116 " XA65 MOS6510 cross assembler | |
117 au BufNewFile,BufRead *.a65 setf a65 | |
118 | |
2034 | 119 " Applescript |
120 au BufNewFile,BufRead *.scpt setf applescript | |
121 | |
7 | 122 " Applix ELF |
123 au BufNewFile,BufRead *.am | |
124 \ if expand("<afile>") !~? 'Makefile.am\>' | setf elf | endif | |
125 | |
24 | 126 " ALSA configuration |
127 au BufNewFile,BufRead ~/.asoundrc,/usr/share/alsa/alsa.conf,/etc/asound.conf setf alsaconf | |
128 | |
7 | 129 " Arc Macro Language |
130 au BufNewFile,BufRead *.aml setf aml | |
131 | |
132 " Arch Inventory file | |
133 au BufNewFile,BufRead .arch-inventory,=tagging-method setf arch | |
134 | |
135 " ART*Enterprise (formerly ART-IM) | |
136 au BufNewFile,BufRead *.art setf art | |
137 | |
138 " ASN.1 | |
139 au BufNewFile,BufRead *.asn,*.asn1 setf asn | |
140 | |
141 " Active Server Pages (with Visual Basic Script) | |
142 au BufNewFile,BufRead *.asa | |
143 \ if exists("g:filetype_asa") | | |
144 \ exe "setf " . g:filetype_asa | | |
145 \ else | | |
146 \ setf aspvbs | | |
147 \ endif | |
148 | |
149 " Active Server Pages (with Perl or Visual Basic Script) | |
150 au BufNewFile,BufRead *.asp | |
151 \ if exists("g:filetype_asp") | | |
152 \ exe "setf " . g:filetype_asp | | |
153 \ elseif getline(1) . getline(2) . getline(3) =~? "perlscript" | | |
154 \ setf aspperl | | |
155 \ else | | |
156 \ setf aspvbs | | |
157 \ endif | |
158 | |
159 " Grub (must be before catch *.lst) | |
819 | 160 au BufNewFile,BufRead /boot/grub/menu.lst,/boot/grub/grub.conf,/etc/grub.conf setf grub |
7 | 161 |
162 " Assembly (all kinds) | |
163 " *.lst is not pure assembly, it has two extra columns (address, byte codes) | |
216 | 164 au BufNewFile,BufRead *.asm,*.[sS],*.[aA],*.mac,*.lst call s:FTasm() |
7 | 165 |
166 " This function checks for the kind of assembly that is wanted by the user, or | |
167 " can be detected from the first five lines of the file. | |
1219 | 168 func! s:FTasm() |
7 | 169 " make sure b:asmsyntax exists |
170 if !exists("b:asmsyntax") | |
171 let b:asmsyntax = "" | |
172 endif | |
173 | |
174 if b:asmsyntax == "" | |
216 | 175 call s:FTasmsyntax() |
7 | 176 endif |
177 | |
178 " if b:asmsyntax still isn't set, default to asmsyntax or GNU | |
179 if b:asmsyntax == "" | |
180 if exists("g:asmsyntax") | |
181 let b:asmsyntax = g:asmsyntax | |
182 else | |
183 let b:asmsyntax = "asm" | |
184 endif | |
185 endif | |
186 | |
1698 | 187 exe "setf " . fnameescape(b:asmsyntax) |
1219 | 188 endfunc |
189 | |
190 func! s:FTasmsyntax() | |
7 | 191 " see if file contains any asmsyntax=foo overrides. If so, change |
192 " b:asmsyntax appropriately | |
193 let head = " ".getline(1)." ".getline(2)." ".getline(3)." ".getline(4). | |
194 \" ".getline(5)." " | |
1698 | 195 let match = matchstr(head, '\sasmsyntax=\zs[a-zA-Z0-9]\+\ze\s') |
196 if match != '' | |
197 let b:asmsyntax = match | |
7 | 198 elseif ((head =~? '\.title') || (head =~? '\.ident') || (head =~? '\.macro') || (head =~? '\.subtitle') || (head =~? '\.library')) |
199 let b:asmsyntax = "vmasm" | |
200 endif | |
1219 | 201 endfunc |
7 | 202 |
203 " Macro (VAX) | |
204 au BufNewFile,BufRead *.mar setf vmasm | |
205 | |
206 " Atlas | |
207 au BufNewFile,BufRead *.atl,*.as setf atlas | |
208 | |
1125 | 209 " Autoit v3 |
210 au BufNewFile,BufRead *.au3 setf autoit | |
211 | |
1219 | 212 " Autohotkey |
213 au BufNewFile,BufRead *.ahk setf autohotkey | |
214 | |
7 | 215 " Automake |
809 | 216 au BufNewFile,BufRead [mM]akefile.am,GNUmakefile.am setf automake |
7 | 217 |
375 | 218 " Autotest .at files are actually m4 |
219 au BufNewFile,BufRead *.at setf m4 | |
220 | |
7 | 221 " Avenue |
222 au BufNewFile,BufRead *.ave setf ave | |
223 | |
224 " Awk | |
225 au BufNewFile,BufRead *.awk setf awk | |
226 | |
227 " B | |
228 au BufNewFile,BufRead *.mch,*.ref,*.imp setf b | |
229 | |
230 " BASIC or Visual Basic | |
216 | 231 au BufNewFile,BufRead *.bas call s:FTVB("basic") |
7 | 232 |
233 " Check if one of the first five lines contains "VB_Name". In that case it is | |
234 " probably a Visual Basic file. Otherwise it's assumed to be "alt" filetype. | |
1219 | 235 func! s:FTVB(alt) |
7 | 236 if getline(1).getline(2).getline(3).getline(4).getline(5) =~? 'VB_Name\|Begin VB\.\(Form\|MDIForm\|UserControl\)' |
237 setf vb | |
238 else | |
239 exe "setf " . a:alt | |
240 endif | |
1219 | 241 endfunc |
7 | 242 |
243 " Visual Basic Script (close to Visual Basic) | |
244 au BufNewFile,BufRead *.vbs,*.dsm,*.ctl setf vb | |
245 | |
1125 | 246 " IBasic file (similar to QBasic) |
247 au BufNewFile,BufRead *.iba,*.ibi setf ibasic | |
248 | |
249 " FreeBasic file (similar to QBasic) | |
250 au BufNewFile,BufRead *.fb,*.bi setf freebasic | |
251 | |
7 | 252 " Batch file for MSDOS. |
15 | 253 au BufNewFile,BufRead *.bat,*.sys setf dosbatch |
7 | 254 " *.cmd is close to a Batch file, but on OS/2 Rexx files also use *.cmd. |
255 au BufNewFile,BufRead *.cmd | |
256 \ if getline(1) =~ '^/\*' | setf rexx | else | setf dosbatch | endif | |
257 | |
258 " Batch file for 4DOS | |
216 | 259 au BufNewFile,BufRead *.btm call s:FTbtm() |
1219 | 260 func! s:FTbtm() |
15 | 261 if exists("g:dosbatch_syntax_for_btm") && g:dosbatch_syntax_for_btm |
262 setf dosbatch | |
263 else | |
264 setf btm | |
265 endif | |
1219 | 266 endfunc |
7 | 267 |
268 " BC calculator | |
269 au BufNewFile,BufRead *.bc setf bc | |
270 | |
271 " BDF font | |
272 au BufNewFile,BufRead *.bdf setf bdf | |
273 | |
274 " BibTeX bibliography database file | |
275 au BufNewFile,BufRead *.bib setf bib | |
276 | |
846 | 277 " BibTeX Bibliography Style |
278 au BufNewFile,BufRead *.bst setf bst | |
279 | |
7 | 280 " BIND configuration |
45 | 281 au BufNewFile,BufRead named.conf,rndc.conf setf named |
7 | 282 |
283 " BIND zone | |
284 au BufNewFile,BufRead named.root setf bindzone | |
805 | 285 au BufNewFile,BufRead *.db call s:BindzoneCheck('') |
286 | |
287 func! s:BindzoneCheck(default) | |
288 if getline(1).getline(2).getline(3).getline(4) =~ '^; <<>> DiG [0-9.]\+ <<>>\|BIND.*named\|$ORIGIN\|$TTL\|IN\s\+SOA' | |
289 setf bindzone | |
290 elseif a:default != '' | |
291 exe 'setf ' . a:default | |
292 endif | |
293 endfunc | |
7 | 294 |
295 " Blank | |
296 au BufNewFile,BufRead *.bl setf blank | |
297 | |
1676 | 298 " Blkid cache file |
299 au BufNewFile,BufRead /etc/blkid.tab,/etc/blkid.tab.old setf xml | |
300 | |
7 | 301 " C or lpc |
216 | 302 au BufNewFile,BufRead *.c call s:FTlpc() |
7 | 303 |
1219 | 304 func! s:FTlpc() |
7 | 305 if exists("g:lpc_syntax_for_c") |
306 let lnum = 1 | |
307 while lnum <= 12 | |
308 if getline(lnum) =~# '^\(//\|inherit\|private\|protected\|nosave\|string\|object\|mapping\|mixed\)' | |
309 setf lpc | |
310 return | |
311 endif | |
312 let lnum = lnum + 1 | |
313 endwhile | |
314 endif | |
315 setf c | |
1219 | 316 endfunc |
7 | 317 |
318 " Calendar | |
216 | 319 au BufNewFile,BufRead calendar setf calendar |
320 au BufNewFile,BufRead */.calendar/*, | |
7 | 321 \*/share/calendar/*/calendar.*,*/share/calendar/calendar.* |
216 | 322 \ call s:StarSetf('calendar') |
7 | 323 |
324 " C# | |
325 au BufNewFile,BufRead *.cs setf cs | |
326 | |
2152 | 327 " Cabal |
328 au BufNewFile,BufRead *.cabal setf cabal | |
329 | |
1219 | 330 " Cdrdao TOC |
331 au BufNewFile,BufRead *.toc setf cdrtoc | |
332 | |
1648 | 333 " Cdrdao config |
334 au BufNewFile,BufRead etc/cdrdao.conf,etc/defaults/cdrdao,etc/default/cdrdao,~/.cdrdao setf cdrdaoconf | |
335 | |
555 | 336 " Cfengine |
337 au BufNewFile,BufRead cfengine.conf setf cfengine | |
338 | |
2152 | 339 " ChaiScript |
340 au BufRead,BufNewFile *.chai setf chaiscript | |
341 | |
7 | 342 " Comshare Dimension Definition Language |
343 au BufNewFile,BufRead *.cdl setf cdl | |
344 | |
1125 | 345 " Conary Recipe |
346 au BufNewFile,BufRead *.recipe setf conaryrecipe | |
347 | |
7 | 348 " Controllable Regex Mutilator |
349 au BufNewFile,BufRead *.crm setf crm | |
350 | |
351 " Cyn++ | |
352 au BufNewFile,BufRead *.cyn setf cynpp | |
353 | |
354 " Cynlib | |
355 " .cc and .cpp files can be C++ or Cynlib. | |
356 au BufNewFile,BufRead *.cc | |
357 \ if exists("cynlib_syntax_for_cc")|setf cynlib|else|setf cpp|endif | |
358 au BufNewFile,BufRead *.cpp | |
359 \ if exists("cynlib_syntax_for_cpp")|setf cynlib|else|setf cpp|endif | |
360 | |
361 " C++ | |
2034 | 362 au BufNewFile,BufRead *.cxx,*.c++,*.hh,*.hxx,*.hpp,*.ipp,*.moc,*.tcc,*.inl setf cpp |
7 | 363 if has("fname_case") |
2034 | 364 au BufNewFile,BufRead *.C,*.H setf cpp |
7 | 365 endif |
366 | |
1648 | 367 " .h files can be C, Ch C++, ObjC or ObjC++. |
368 " Set c_syntax_for_h if you want C, ch_syntax_for_h if you want Ch. ObjC is | |
369 " detected automatically. | |
370 au BufNewFile,BufRead *.h call s:FTheader() | |
371 | |
372 func! s:FTheader() | |
373 if match(getline(1, min([line("$"), 200])), '^@\(interface\|end\|class\)') > -1 | |
374 setf objc | |
2034 | 375 elseif exists("g:c_syntax_for_h") |
1648 | 376 setf c |
2034 | 377 elseif exists("g:ch_syntax_for_h") |
1648 | 378 setf ch |
379 else | |
380 setf cpp | |
381 endif | |
382 endfunc | |
7 | 383 |
384 " Ch (CHscript) | |
385 au BufNewFile,BufRead *.chf setf ch | |
386 | |
387 " TLH files are C++ headers generated by Visual C++'s #import from typelibs | |
388 au BufNewFile,BufRead *.tlh setf cpp | |
389 | |
390 " Cascading Style Sheets | |
391 au BufNewFile,BufRead *.css setf css | |
392 | |
393 " Century Term Command Scripts (*.cmd too) | |
394 au BufNewFile,BufRead *.con setf cterm | |
395 | |
396 " Changelog | |
809 | 397 au BufNewFile,BufRead changelog.Debian,changelog.dch,NEWS.Debian,NEWS.dch |
398 \ setf debchangelog | |
399 | |
400 au BufNewFile,BufRead [cC]hange[lL]og | |
401 \ if getline(1) =~ '; urgency=' | |
402 \| setf debchangelog | |
403 \| else | |
404 \| setf changelog | |
405 \| endif | |
406 | |
407 au BufNewFile,BufRead NEWS | |
408 \ if getline(1) =~ '; urgency=' | |
409 \| setf debchangelog | |
410 \| endif | |
7 | 411 |
412 " CHILL | |
413 au BufNewFile,BufRead *..ch setf chill | |
414 | |
415 " Changes for WEB and CWEB or CHILL | |
216 | 416 au BufNewFile,BufRead *.ch call s:FTchange() |
7 | 417 |
418 " This function checks if one of the first ten lines start with a '@'. In | |
419 " that case it is probably a change file. | |
420 " If the first line starts with # or ! it's probably a ch file. | |
421 " If a line has "main", "include", "//" ir "/*" it's probably ch. | |
422 " Otherwise CHILL is assumed. | |
1219 | 423 func! s:FTchange() |
7 | 424 let lnum = 1 |
425 while lnum <= 10 | |
426 if getline(lnum)[0] == '@' | |
427 setf change | |
428 return | |
429 endif | |
430 if lnum == 1 && (getline(1)[0] == '#' || getline(1)[0] == '!') | |
431 setf ch | |
432 return | |
433 endif | |
434 if getline(lnum) =~ "MODULE" | |
435 setf chill | |
436 return | |
437 endif | |
438 if getline(lnum) =~ 'main\s*(\|#\s*include\|//' | |
439 setf ch | |
440 return | |
441 endif | |
442 let lnum = lnum + 1 | |
443 endwhile | |
444 setf chill | |
1219 | 445 endfunc |
7 | 446 |
839 | 447 " ChordPro |
448 au BufNewFile,BufRead *.chopro,*.crd,*.cho,*.crdpro,*.chordpro setf chordpro | |
449 | |
7 | 450 " Clean |
451 au BufNewFile,BufRead *.dcl,*.icl setf clean | |
452 | |
453 " Clever | |
454 au BufNewFile,BufRead *.eni setf cl | |
455 | |
456 " Clever or dtd | |
216 | 457 au BufNewFile,BufRead *.ent call s:FTent() |
7 | 458 |
1219 | 459 func! s:FTent() |
7 | 460 " This function checks for valid cl syntax in the first five lines. |
461 " Look for either an opening comment, '#', or a block start, '{". | |
462 " If not found, assume SGML. | |
463 let lnum = 1 | |
464 while lnum < 6 | |
465 let line = getline(lnum) | |
466 if line =~ '^\s*[#{]' | |
467 setf cl | |
468 return | |
469 elseif line !~ '^\s*$' | |
470 " Not a blank line, not a comment, and not a block start, | |
471 " so doesn't look like valid cl code. | |
472 break | |
473 endif | |
474 let lnum = lnum + 1 | |
475 endw | |
476 setf dtd | |
1219 | 477 endfunc |
7 | 478 |
625 | 479 " Clipper (or FoxPro; could also be eviews) |
7 | 480 au BufNewFile,BufRead *.prg |
481 \ if exists("g:filetype_prg") | | |
482 \ exe "setf " . g:filetype_prg | | |
483 \ else | | |
484 \ setf clipper | | |
485 \ endif | |
486 | |
836 | 487 " Cmake |
488 au BufNewFile,BufRead CMakeLists.txt,*.cmake,*.cmake.in setf cmake | |
489 | |
1125 | 490 " Cmusrc |
491 au BufNewFile,BufRead ~/.cmus/{autosave,rc,command-history,*.theme} setf cmusrc | |
492 au BufNewFile,BufRead */cmus/{rc,*.theme} setf cmusrc | |
493 | |
7 | 494 " Cobol |
809 | 495 au BufNewFile,BufRead *.cbl,*.cob,*.lib setf cobol |
496 " cobol or zope form controller python script? (heuristic) | |
497 au BufNewFile,BufRead *.cpy | |
498 \ if getline(1) =~ '^##' | | |
499 \ setf python | | |
500 \ else | | |
501 \ setf cobol | | |
502 \ endif | |
7 | 503 |
1648 | 504 " Coco/R |
505 au BufNewFile,BufRead *.atg setf coco | |
506 | |
7 | 507 " Cold Fusion |
508 au BufNewFile,BufRead *.cfm,*.cfi,*.cfc setf cf | |
509 | |
510 " Configure scripts | |
511 au BufNewFile,BufRead configure.in,configure.ac setf config | |
512 | |
1648 | 513 " CUDA Cumpute Unified Device Architecture |
514 au BufNewFile,BufRead *.cu setf cuda | |
515 | |
7 | 516 " WildPackets EtherPeek Decoder |
517 au BufNewFile,BufRead *.dcd setf dcd | |
518 | |
519 " Enlightenment configuration files | |
520 au BufNewFile,BufRead *enlightenment/*.cfg setf c | |
521 | |
522 " Eterm | |
523 au BufNewFile,BufRead *Eterm/*.cfg setf eterm | |
524 | |
525 " Lynx config files | |
526 au BufNewFile,BufRead lynx.cfg setf lynx | |
527 | |
528 " Quake | |
529 au BufNewFile,BufRead *baseq[2-3]/*.cfg,*id1/*.cfg setf quake | |
530 au BufNewFile,BufRead *quake[1-3]/*.cfg setf quake | |
531 | |
532 " Quake C | |
533 au BufNewFile,BufRead *.qc setf c | |
534 | |
535 " Configure files | |
536 au BufNewFile,BufRead *.cfg setf cfg | |
537 | |
2098
3259c3923c1e
Updated runtime an documentation files.
Bram Moolenaar <bram@zimbu.org>
parents:
2034
diff
changeset
|
538 " Cucumber |
3259c3923c1e
Updated runtime an documentation files.
Bram Moolenaar <bram@zimbu.org>
parents:
2034
diff
changeset
|
539 au BufNewFile,BufRead *.feature setf cucumber |
3259c3923c1e
Updated runtime an documentation files.
Bram Moolenaar <bram@zimbu.org>
parents:
2034
diff
changeset
|
540 |
7 | 541 " Communicating Sequential Processes |
542 au BufNewFile,BufRead *.csp,*.fdr setf csp | |
543 | |
544 " CUPL logic description and simulation | |
545 au BufNewFile,BufRead *.pld setf cupl | |
546 au BufNewFile,BufRead *.si setf cuplsim | |
547 | |
548 " Debian Control | |
549 au BufNewFile,BufRead */debian/control setf debcontrol | |
1648 | 550 au BufNewFile,BufRead control |
551 \ if getline(1) =~ '^Source:' | |
552 \| setf debcontrol | |
553 \| endif | |
7 | 554 |
816 | 555 " Debian Sources.list |
556 au BufNewFile,BufRead /etc/apt/sources.list setf debsources | |
557 | |
1648 | 558 " Deny hosts |
559 au BufNewFile,BufRead denyhosts.conf setf denyhosts | |
560 | |
7 | 561 " ROCKLinux package description |
562 au BufNewFile,BufRead *.desc setf desc | |
563 | |
1648 | 564 " the D language or dtrace |
565 au BufNewFile,BufRead *.d call s:DtraceCheck() | |
566 | |
567 func! s:DtraceCheck() | |
568 let lines = getline(1, min([line("$"), 100])) | |
569 if match(lines, '^#!\S\+dtrace\|#pragma\s\+D\s\+option\|:\S\{-}:\S\{-}:') > -1 | |
570 setf dtrace | |
571 else | |
572 setf d | |
573 endif | |
574 endfunc | |
7 | 575 |
576 " Desktop files | |
577 au BufNewFile,BufRead *.desktop,.directory setf desktop | |
578 | |
389 | 579 " Dict config |
580 au BufNewFile,BufRead dict.conf,.dictrc setf dictconf | |
581 | |
582 " Dictd config | |
583 au BufNewFile,BufRead dictd.conf setf dictdconf | |
584 | |
7 | 585 " Diff files |
586 au BufNewFile,BufRead *.diff,*.rej,*.patch setf diff | |
587 | |
588 " Dircolors | |
589 au BufNewFile,BufRead .dir_colors,/etc/DIR_COLORS setf dircolors | |
590 | |
591 " Diva (with Skill) or InstallShield | |
592 au BufNewFile,BufRead *.rul | |
593 \ if getline(1).getline(2).getline(3).getline(4).getline(5).getline(6) =~? 'InstallShield' | | |
594 \ setf ishd | | |
595 \ else | | |
596 \ setf diva | | |
597 \ endif | |
598 | |
599 " DCL (Digital Command Language - vms) or DNS zone file | |
805 | 600 au BufNewFile,BufRead *.com call s:BindzoneCheck('dcl') |
7 | 601 |
602 " DOT | |
603 au BufNewFile,BufRead *.dot setf dot | |
604 | |
605 " Dylan - lid files | |
606 au BufNewFile,BufRead *.lid setf dylanlid | |
607 | |
608 " Dylan - intr files (melange) | |
609 au BufNewFile,BufRead *.intr setf dylanintr | |
610 | |
611 " Dylan | |
612 au BufNewFile,BufRead *.dylan setf dylan | |
613 | |
614 " Microsoft Module Definition | |
615 au BufNewFile,BufRead *.def setf def | |
616 | |
617 " Dracula | |
618 au BufNewFile,BufRead *.drac,*.drc,*lvs,*lpe setf dracula | |
619 | |
620 " dsl | |
621 au BufNewFile,BufRead *.dsl setf dsl | |
622 | |
623 " DTD (Document Type Definition for XML) | |
624 au BufNewFile,BufRead *.dtd setf dtd | |
625 | |
626 " EDIF (*.edf,*.edif,*.edn,*.edo) | |
627 au BufNewFile,BufRead *.ed\(f\|if\|n\|o\) setf edif | |
628 | |
629 " Embedix Component Description | |
630 au BufNewFile,BufRead *.ecd setf ecd | |
631 | |
632 " Eiffel or Specman | |
216 | 633 au BufNewFile,BufRead *.e,*.E call s:FTe() |
7 | 634 |
635 " Elinks configuration | |
636 au BufNewFile,BufRead */etc/elinks.conf,*/.elinks/elinks.conf setf elinks | |
637 | |
1219 | 638 func! s:FTe() |
7 | 639 let n = 1 |
640 while n < 100 && n < line("$") | |
641 if getline(n) =~ "^\\s*\\(<'\\|'>\\)\\s*$" | |
642 setf specman | |
643 return | |
644 endif | |
645 let n = n + 1 | |
646 endwhile | |
647 setf eiffel | |
1219 | 648 endfunc |
7 | 649 |
1648 | 650 " ERicsson LANGuage; Yaws is erlang too |
1668 | 651 au BufNewFile,BufRead *.erl,*.hrl,*.yaws setf erlang |
7 | 652 |
653 " Elm Filter Rules file | |
654 au BufNewFile,BufRead filter-rules setf elmfilt | |
655 | |
168 | 656 " ESMTP rc file |
657 au BufNewFile,BufRead *esmtprc setf esmtprc | |
658 | |
7 | 659 " ESQL-C |
660 au BufNewFile,BufRead *.ec,*.EC setf esqlc | |
661 | |
278 | 662 " Esterel |
663 au BufNewFile,BufRead *.strl setf esterel | |
664 | |
7 | 665 " Essbase script |
666 au BufNewFile,BufRead *.csc setf csc | |
667 | |
668 " Exim | |
669 au BufNewFile,BufRead exim.conf setf exim | |
670 | |
671 " Expect | |
672 au BufNewFile,BufRead *.exp setf expect | |
673 | |
674 " Exports | |
675 au BufNewFile,BufRead exports setf exports | |
676 | |
333 | 677 " Factor |
678 au BufNewFile,BufRead *.factor setf factor | |
679 | |
7 | 680 " Fetchmail RC file |
681 au BufNewFile,BufRead .fetchmailrc setf fetchmail | |
682 | |
2034 | 683 " FlexWiki - disabled, because it has side effects when a .wiki file |
684 " is not actually FlexWiki | |
685 "au BufNewFile,BufRead *.wiki setf flexwiki | |
846 | 686 |
7 | 687 " Focus Executable |
688 au BufNewFile,BufRead *.fex,*.focexec setf focexec | |
689 | |
690 " Focus Master file (but not for auto.master) | |
691 au BufNewFile,BufRead auto.master setf conf | |
692 au BufNewFile,BufRead *.mas,*.master setf master | |
693 | |
694 " Forth | |
695 au BufNewFile,BufRead *.fs,*.ft setf forth | |
696 | |
1648 | 697 " Reva Forth |
698 au BufNewFile,BufRead *.frt setf reva | |
699 | |
7 | 700 " Fortran |
1125 | 701 if has("fname_case") |
702 au BufNewFile,BufRead *.F,*.FOR,*.FPP,*.FTN,*.F77,*.F90,*.F95 setf fortran | |
703 endif | |
1648 | 704 au BufNewFile,BufRead *.f,*.for,*.fortran,*.fpp,*.ftn,*.f77,*.f90,*.f95 setf fortran |
7 | 705 |
1698 | 706 " Framescript |
707 au BufNewFile,BufRead *.fsl setf framescript | |
708 | |
7 | 709 " FStab |
819 | 710 au BufNewFile,BufRead fstab,mtab setf fstab |
7 | 711 |
712 " GDB command files | |
713 au BufNewFile,BufRead .gdbinit setf gdb | |
714 | |
715 " GDMO | |
716 au BufNewFile,BufRead *.mo,*.gdmo setf gdmo | |
717 | |
718 " Gedcom | |
2034 | 719 au BufNewFile,BufRead *.ged,lltxxxxx.txt setf gedcom |
7 | 720 |
1648 | 721 " Git |
2034 | 722 autocmd BufNewFile,BufRead *.git/COMMIT_EDITMSG setf gitcommit |
723 autocmd BufNewFile,BufRead *.git/config,.gitconfig,.gitmodules setf gitconfig | |
724 autocmd BufNewFile,BufRead git-rebase-todo setf gitrebase | |
1648 | 725 autocmd BufNewFile,BufRead .msg.[0-9]* |
726 \ if getline(1) =~ '^From.*# This line is ignored.$' | | |
727 \ setf gitsendemail | | |
728 \ endif | |
729 autocmd BufNewFile,BufRead *.git/** | |
730 \ if getline(1) =~ '^\x\{40\}\>\|^ref: ' | | |
731 \ setf git | | |
732 \ endif | |
733 | |
7 | 734 " Gkrellmrc |
735 au BufNewFile,BufRead gkrellmrc,gkrellmrc_? setf gkrellmrc | |
736 | |
737 " GP scripts (2.0 and onward) | |
827 | 738 au BufNewFile,BufRead *.gp,.gprc setf gp |
7 | 739 |
740 " GPG | |
741 au BufNewFile,BufRead */.gnupg/options setf gpg | |
742 au BufNewFile,BufRead */.gnupg/gpg.conf setf gpg | |
743 au BufNewFile,BufRead /usr/**/gnupg/options.skel setf gpg | |
744 | |
745 " Gnuplot scripts | |
746 au BufNewFile,BufRead *.gpi setf gnuplot | |
747 | |
748 " GrADS scripts | |
749 au BufNewFile,BufRead *.gs setf grads | |
750 | |
625 | 751 " Gretl |
752 au BufNewFile,BufRead *.gretl setf gretl | |
753 | |
7 | 754 " Groovy |
755 au BufNewFile,BufRead *.groovy setf groovy | |
756 | |
757 " GNU Server Pages | |
758 au BufNewFile,BufRead *.gsp setf gsp | |
759 | |
389 | 760 " Group file |
1676 | 761 au BufNewFile,BufRead /etc/group,/etc/group-,/etc/group.edit,/etc/gshadow,/etc/gshadow-,/etc/gshadow.edit,/var/backups/group.bak,/var/backups/gshadow.bak setf group |
389 | 762 |
7 | 763 " GTK RC |
764 au BufNewFile,BufRead .gtkrc,gtkrc setf gtkrc | |
765 | |
1668 | 766 " Haml |
767 au BufNewFile,BufRead *.haml setf haml | |
768 | |
1125 | 769 " Hamster Classic | Playground files |
770 au BufNewFile,BufRead *.hsc,*.hsm setf hamster | |
771 | |
7 | 772 " Haskell |
2152 | 773 au BufNewFile,BufRead *.hs,*.hs-boot setf haskell |
7 | 774 au BufNewFile,BufRead *.lhs setf lhaskell |
775 au BufNewFile,BufRead *.chs setf chaskell | |
776 | |
1648 | 777 " Haste |
778 au BufNewFile,BufRead *.ht setf haste | |
1668 | 779 au BufNewFile,BufRead *.htpp setf hastepreproc |
1648 | 780 |
7 | 781 " Hercules |
782 au BufNewFile,BufRead *.vc,*.ev,*.rs,*.sum,*.errsum setf hercules | |
783 | |
784 " HEX (Intel) | |
785 au BufNewFile,BufRead *.hex,*.h32 setf hex | |
786 | |
787 " Tilde (must be before HTML) | |
788 au BufNewFile,BufRead *.t.html setf tilde | |
789 | |
497 | 790 " HTML (.shtml and .stm for server side) |
791 au BufNewFile,BufRead *.html,*.htm,*.shtml,*.stm call s:FThtml() | |
7 | 792 |
798 | 793 " Distinguish between HTML, XHTML and Django |
1219 | 794 func! s:FThtml() |
7 | 795 let n = 1 |
796 while n < 10 && n < line("$") | |
797 if getline(n) =~ '\<DTD\s\+XHTML\s' | |
798 setf xhtml | |
799 return | |
800 endif | |
798 | 801 if getline(n) =~ '{%\s*\(extends\|block\)\>' |
802 setf htmldjango | |
803 return | |
804 endif | |
7 | 805 let n = n + 1 |
806 endwhile | |
807 setf html | |
1219 | 808 endfunc |
7 | 809 |
497 | 810 " HTML with Ruby - eRuby |
1219 | 811 au BufNewFile,BufRead *.erb,*.rhtml setf eruby |
7 | 812 |
813 " HTML with M4 | |
814 au BufNewFile,BufRead *.html.m4 setf htmlm4 | |
815 | |
816 " HTML Cheetah template | |
817 au BufNewFile,BufRead *.tmpl setf htmlcheetah | |
818 | |
1648 | 819 " Host config |
820 au BufNewFile,BufRead /etc/host.conf setf hostconf | |
821 | |
1676 | 822 " Hosts access |
823 au BufNewFile,BufRead /etc/hosts.allow,/etc/hosts.deny setf hostsaccess | |
824 | |
7 | 825 " Hyper Builder |
826 au BufNewFile,BufRead *.hb setf hb | |
827 | |
828 " Icon | |
829 au BufNewFile,BufRead *.icn setf icon | |
830 | |
831 " IDL (Interface Description Language) | |
216 | 832 au BufNewFile,BufRead *.idl call s:FTidl() |
7 | 833 |
834 " Distinguish between standard IDL and MS-IDL | |
1219 | 835 func! s:FTidl() |
7 | 836 let n = 1 |
837 while n < 50 && n < line("$") | |
838 if getline(n) =~ '^\s*import\s\+"\(unknwn\|objidl\)\.idl"' | |
839 setf msidl | |
840 return | |
841 endif | |
842 let n = n + 1 | |
843 endwhile | |
844 setf idl | |
1219 | 845 endfunc |
7 | 846 |
847 " Microsoft IDL (Interface Description Language) Also *.idl | |
848 " MOF = WMI (Windows Management Instrumentation) Managed Object Format | |
849 au BufNewFile,BufRead *.odl,*.mof setf msidl | |
850 | |
851 " Icewm menu | |
852 au BufNewFile,BufRead */.icewm/menu setf icemenu | |
853 | |
1219 | 854 " Indent profile (must come before IDL *.pro!) |
855 au BufNewFile,BufRead .indent.pro setf indent | |
856 au BufNewFile,BufRead indent.pro call s:ProtoCheck('indent') | |
857 | |
7 | 858 " IDL (Interactive Data Language) |
1219 | 859 au BufNewFile,BufRead *.pro call s:ProtoCheck('idlang') |
860 | |
861 " Distinguish between "default" and Cproto prototype file. */ | |
862 func! s:ProtoCheck(default) | |
863 " Cproto files have a comment in the first line and a function prototype in | |
864 " the second line, it always ends in ";". Indent files may also have | |
865 " comments, thus we can't match comments to see the difference. | |
866 if getline(2) =~ ';$' | |
867 setf cpp | |
868 else | |
869 exe 'setf ' . a:default | |
870 endif | |
871 endfunc | |
872 | |
7 | 873 |
389 | 874 " Indent RC |
1676 | 875 au BufNewFile,BufRead indentrc setf indent |
389 | 876 |
7 | 877 " Inform |
878 au BufNewFile,BufRead *.inf,*.INF setf inform | |
879 | |
1125 | 880 " Initng |
881 au BufNewFile,BufRead /etc/initng/**/*.i,*.ii setf initng | |
882 | |
148 | 883 " Ipfilter |
1125 | 884 au BufNewFile,BufRead ipf.conf,ipf6.conf,ipf.rules setf ipfilter |
148 | 885 |
7 | 886 " Informix 4GL (source - canonical, include file, I4GL+M4 preproc.) |
887 au BufNewFile,BufRead *.4gl,*.4gh,*.m4gl setf fgl | |
888 | |
889 " .INI file for MSDOS | |
890 au BufNewFile,BufRead *.ini setf dosini | |
891 | |
892 " SysV Inittab | |
893 au BufNewFile,BufRead inittab setf inittab | |
894 | |
895 " Inno Setup | |
896 au BufNewFile,BufRead *.iss setf iss | |
897 | |
898 " JAL | |
899 au BufNewFile,BufRead *.jal,*.JAL setf jal | |
900 | |
901 " Jam | |
902 au BufNewFile,BufRead *.jpl,*.jpr setf jam | |
903 | |
904 " Java | |
905 au BufNewFile,BufRead *.java,*.jav setf java | |
906 | |
907 " JavaCC | |
908 au BufNewFile,BufRead *.jj,*.jjt setf javacc | |
909 | |
1125 | 910 " JavaScript, ECMAScript |
2034 | 911 au BufNewFile,BufRead *.js,*.javascript,*.es,*.jsx setf javascript |
7 | 912 |
913 " Java Server Pages | |
914 au BufNewFile,BufRead *.jsp setf jsp | |
915 | |
916 " Java Properties resource file (note: doesn't catch font.properties.pl) | |
216 | 917 au BufNewFile,BufRead *.properties,*.properties_??,*.properties_??_?? setf jproperties |
918 au BufNewFile,BufRead *.properties_??_??_* call s:StarSetf('jproperties') | |
7 | 919 |
920 " Jess | |
921 au BufNewFile,BufRead *.clp setf jess | |
922 | |
923 " Jgraph | |
924 au BufNewFile,BufRead *.jgr setf jgraph | |
925 | |
926 " Kixtart | |
927 au BufNewFile,BufRead *.kix setf kix | |
928 | |
929 " Kimwitu[++] | |
930 au BufNewFile,BufRead *.k setf kwt | |
931 | |
932 " KDE script | |
933 au BufNewFile,BufRead *.ks setf kscript | |
934 | |
826 | 935 " Kconfig |
936 au BufNewFile,BufRead Kconfig,Kconfig.debug setf kconfig | |
937 | |
7 | 938 " Lace (ISE) |
939 au BufNewFile,BufRead *.ace,*.ACE setf lace | |
940 | |
941 " Latte | |
942 au BufNewFile,BufRead *.latte,*.lte setf latte | |
943 | |
375 | 944 " Limits |
945 au BufNewFile,BufRead /etc/limits setf limits | |
946 | |
7 | 947 " LambdaProlog (*.mod too, see Modsim) |
948 au BufNewFile,BufRead *.sig setf lprolog | |
949 | |
950 " LDAP LDIF | |
951 au BufNewFile,BufRead *.ldif setf ldif | |
952 | |
375 | 953 " Ld loader |
954 au BufNewFile,BufRead *.ld setf ld | |
955 | |
7 | 956 " Lex |
957 au BufNewFile,BufRead *.lex,*.l setf lex | |
958 | |
959 " Libao | |
960 au BufNewFile,BufRead /etc/libao.conf,*/.libao setf libao | |
961 | |
389 | 962 " Libsensors |
963 au BufNewFile,BufRead /etc/sensors.conf setf sensors | |
964 | |
7 | 965 " LFTP |
966 au BufNewFile,BufRead lftp.conf,.lftprc,*lftp/rc setf lftp | |
967 | |
968 " Lifelines (or Lex for C++!) | |
969 au BufNewFile,BufRead *.ll setf lifelines | |
970 | |
971 " Lilo: Linux loader | |
216 | 972 au BufNewFile,BufRead lilo.conf* call s:StarSetf('lilo') |
7 | 973 |
974 " Lisp (*.el = ELisp, *.cl = Common Lisp, *.jl = librep Lisp) | |
975 if has("fname_case") | |
976 au BufNewFile,BufRead *.lsp,*.lisp,*.el,*.cl,*.jl,*.L,.emacs,.sawfishrc setf lisp | |
977 else | |
978 au BufNewFile,BufRead *.lsp,*.lisp,*.el,*.cl,*.jl,.emacs,.sawfishrc setf lisp | |
979 endif | |
980 | |
375 | 981 " SBCL implementation of Common Lisp |
982 au BufNewFile,BufRead sbclrc,.sbclrc setf lisp | |
983 | |
2202 | 984 " Liquid |
985 au BufNewFile,BufRead *.liquid setf liquid | |
986 | |
7 | 987 " Lite |
988 au BufNewFile,BufRead *.lite,*.lt setf lite | |
989 | |
1219 | 990 " LiteStep RC files |
991 au BufNewFile,BufRead */LiteStep/*/*.rc setf litestep | |
992 | |
375 | 993 " Login access |
994 au BufNewFile,BufRead /etc/login.access setf loginaccess | |
995 | |
996 " Login defs | |
997 au BufNewFile,BufRead /etc/login.defs setf logindefs | |
998 | |
7 | 999 " Logtalk |
1000 au BufNewFile,BufRead *.lgt setf logtalk | |
1001 | |
1002 " LOTOS | |
1003 au BufNewFile,BufRead *.lot,*.lotos setf lotos | |
1004 | |
1005 " Lout (also: *.lt) | |
1006 au BufNewFile,BufRead *.lou,*.lout setf lout | |
1007 | |
1008 " Lua | |
1009 au BufNewFile,BufRead *.lua setf lua | |
1010 | |
1648 | 1011 " Linden Scripting Language (Second Life) |
1012 au BufNewFile,BufRead *.lsl setf lsl | |
1013 | |
7 | 1014 " Lynx style file (or LotusScript!) |
1015 au BufNewFile,BufRead *.lss setf lss | |
1016 | |
1017 " M4 | |
1018 au BufNewFile,BufRead *.m4 | |
1019 \ if expand("<afile>") !~? 'html.m4$\|fvwm2rc' | setf m4 | endif | |
1020 | |
1021 " MaGic Point | |
1022 au BufNewFile,BufRead *.mgp setf mgp | |
1023 | |
1125 | 1024 " Mail (for Elm, trn, mutt, muttng, rn, slrn) |
1648 | 1025 au BufNewFile,BufRead snd.\d\+,.letter,.letter.\d\+,.followup,.article,.article.\d\+,pico.\d\+,mutt{ng,}-*-\w\+,mutt[[:alnum:]_-]\{6\},ae\d\+.txt,/tmp/SLRN[0-9A-Z.]\+,*.eml setf mail |
7 | 1026 |
809 | 1027 " Mail aliases |
1028 au BufNewFile,BufRead /etc/mail/aliases,/etc/aliases setf mailaliases | |
1029 | |
7 | 1030 " Mailcap configuration file |
1031 au BufNewFile,BufRead .mailcap,mailcap setf mailcap | |
1032 | |
1033 " Makefile | |
1034 au BufNewFile,BufRead *[mM]akefile,*.mk,*.mak,*.dsp setf make | |
1035 | |
1036 " MakeIndex | |
1037 au BufNewFile,BufRead *.ist,*.mst setf ist | |
1038 | |
1039 " Manpage | |
1040 au BufNewFile,BufRead *.man setf man | |
1041 | |
389 | 1042 " Man config |
819 | 1043 au BufNewFile,BufRead /etc/man.conf,man.config setf manconf |
389 | 1044 |
7 | 1045 " Maple V |
1046 au BufNewFile,BufRead *.mv,*.mpl,*.mws setf maple | |
1047 | |
1668 | 1048 " Map (UMN mapserver config file) |
1049 au BufNewFile,BufRead *.map setf map | |
1050 | |
2202 | 1051 " Markdown |
1052 au BufNewFile,BufRead *.markdown,*.mdown,*.mkd,*.mkdn,README.md setf markdown | |
1053 | |
7 | 1054 " Mason |
1055 au BufNewFile,BufRead *.mason,*.mhtml setf mason | |
1056 | |
1057 " Matlab or Objective C | |
216 | 1058 au BufNewFile,BufRead *.m call s:FTm() |
7 | 1059 |
1219 | 1060 func! s:FTm() |
7 | 1061 let n = 1 |
1062 while n < 10 | |
1063 let line = getline(n) | |
2034 | 1064 if line =~ '^\s*\(#\s*\(include\|import\)\>\|/\*\|//\)' |
7 | 1065 setf objc |
1066 return | |
1067 endif | |
1068 if line =~ '^\s*%' | |
1069 setf matlab | |
1070 return | |
1071 endif | |
1072 if line =~ '^\s*(\*' | |
1073 setf mma | |
1074 return | |
1075 endif | |
1076 let n = n + 1 | |
1077 endwhile | |
271 | 1078 if exists("g:filetype_m") |
1079 exe "setf " . g:filetype_m | |
1080 else | |
1081 setf matlab | |
1082 endif | |
1219 | 1083 endfunc |
7 | 1084 |
1648 | 1085 " Mathematica notebook |
1086 au BufNewFile,BufRead *.nb setf mma | |
1087 | |
7 | 1088 " Maya Extension Language |
1089 au BufNewFile,BufRead *.mel setf mel | |
1090 | |
2034 | 1091 " Mercurial config (looks like generic config file) |
1092 au BufNewFile,BufRead *.hgrc,*hgrc setf cfg | |
1093 | |
1125 | 1094 " Messages |
1095 au BufNewFile,BufRead /var/log/messages,/var/log/messages.*[0-9] setf messages | |
1096 | |
7 | 1097 " Metafont |
1098 au BufNewFile,BufRead *.mf setf mf | |
1099 | |
1100 " MetaPost | |
1101 au BufNewFile,BufRead *.mp setf mp | |
1102 | |
683 | 1103 " MGL |
1104 au BufNewFile,BufRead *.mgl setf mgl | |
1105 | |
7 | 1106 " MMIX or VMS makefile |
216 | 1107 au BufNewFile,BufRead *.mms call s:FTmms() |
7 | 1108 |
1648 | 1109 " Symbian meta-makefile definition (MMP) |
1110 au BufNewFile,BufRead *.mmp setf mmp | |
1111 | |
1219 | 1112 func! s:FTmms() |
7 | 1113 let n = 1 |
1114 while n < 10 | |
1115 let line = getline(n) | |
1116 if line =~ '^\s*\(%\|//\)' || line =~ '^\*' | |
1117 setf mmix | |
1118 return | |
1119 endif | |
1120 if line =~ '^\s*#' | |
1121 setf make | |
1122 return | |
1123 endif | |
1124 let n = n + 1 | |
1125 endwhile | |
1126 setf mmix | |
1219 | 1127 endfunc |
7 | 1128 |
1129 | |
1130 " Modsim III (or LambdaProlog) | |
1131 au BufNewFile,BufRead *.mod | |
1132 \ if getline(1) =~ '\<module\>' | | |
1133 \ setf lprolog | | |
1134 \ else | | |
1135 \ setf modsim3 | | |
1136 \ endif | |
1137 | |
1138 " Modula 2 | |
1139 au BufNewFile,BufRead *.m2,*.DEF,*.MOD,*.md,*.mi setf modula2 | |
1140 | |
1141 " Modula 3 (.m3, .i3, .mg, .ig) | |
1142 au BufNewFile,BufRead *.[mi][3g] setf modula3 | |
1143 | |
1144 " Monk | |
1145 au BufNewFile,BufRead *.isc,*.monk,*.ssc,*.tsc setf monk | |
1146 | |
1147 " MOO | |
1148 au BufNewFile,BufRead *.moo setf moo | |
1149 | |
1150 " Modconf | |
1151 au BufNewFile,BufRead /etc/modules.conf,/etc/conf.modules setf modconf | |
1152 au BufNewFile,BufRead /etc/modutils/* | |
216 | 1153 \ if executable(expand("<afile>")) != 1 |
1154 \| call s:StarSetf('modconf') | |
1155 \|endif | |
7 | 1156 |
1157 " Mplayer config | |
1158 au BufNewFile,BufRead mplayer.conf,*/.mplayer/config setf mplayerconf | |
1159 | |
1160 " Moterola S record | |
1161 au BufNewFile,BufRead *.s19,*.s28,*.s37 setf srec | |
1162 | |
846 | 1163 " Mrxvtrc |
1164 au BufNewFile,BufRead mrxvtrc,.mrxvtrc setf mrxvtrc | |
1165 | |
7 | 1166 " Msql |
1167 au BufNewFile,BufRead *.msql setf msql | |
1168 | |
1169 " Mysql | |
1170 au BufNewFile,BufRead *.mysql setf mysql | |
1171 | |
1172 " M$ Resource files | |
1173 au BufNewFile,BufRead *.rc setf rc | |
1174 | |
12 | 1175 " MuPAD source |
1176 au BufRead,BufNewFile *.mu setf mupad | |
1177 | |
7 | 1178 " Mush |
1179 au BufNewFile,BufRead *.mush setf mush | |
1180 | |
1125 | 1181 " Mutt setup file (also for Muttng) |
1648 | 1182 au BufNewFile,BufRead Mutt{ng,}rc setf muttrc |
7 | 1183 |
389 | 1184 " Nano |
1185 au BufNewFile,BufRead /etc/nanorc,.nanorc setf nanorc | |
1186 | |
7 | 1187 " Nastran input/DMAP |
1188 "au BufNewFile,BufRead *.dat setf nastran | |
1189 | |
1190 " Natural | |
1191 au BufNewFile,BufRead *.NS[ACGLMNPS] setf natural | |
1192 | |
39 | 1193 " Netrc |
1194 au BufNewFile,BufRead .netrc setf netrc | |
1195 | |
7 | 1196 " Novell netware batch files |
1197 au BufNewFile,BufRead *.ncf setf ncf | |
1198 | |
1199 " Nroff/Troff (*.ms and *.t are checked below) | |
1200 au BufNewFile,BufRead *.me | |
1201 \ if expand("<afile>") != "read.me" && expand("<afile>") != "click.me" | | |
1202 \ setf nroff | | |
1203 \ endif | |
1204 au BufNewFile,BufRead *.tr,*.nr,*.roff,*.tmac,*.mom setf nroff | |
216 | 1205 au BufNewFile,BufRead *.[1-9] call s:FTnroff() |
7 | 1206 |
1207 " This function checks if one of the first five lines start with a dot. In | |
1208 " that case it is probably an nroff file: 'filetype' is set and 1 is returned. | |
1219 | 1209 func! s:FTnroff() |
7 | 1210 if getline(1)[0] . getline(2)[0] . getline(3)[0] . getline(4)[0] . getline(5)[0] =~ '\.' |
1211 setf nroff | |
1212 return 1 | |
1213 endif | |
1214 return 0 | |
1219 | 1215 endfunc |
7 | 1216 |
1217 " Nroff or Objective C++ | |
216 | 1218 au BufNewFile,BufRead *.mm call s:FTmm() |
7 | 1219 |
1219 | 1220 func! s:FTmm() |
7 | 1221 let n = 1 |
1222 while n < 10 | |
1223 let line = getline(n) | |
1224 if line =~ '^\s*\(#\s*\(include\|import\)\>\|/\*\)' | |
1225 setf objcpp | |
1226 return | |
1227 endif | |
1228 let n = n + 1 | |
1229 endwhile | |
1230 setf nroff | |
1219 | 1231 endfunc |
7 | 1232 |
1233 " Not Quite C | |
1234 au BufNewFile,BufRead *.nqc setf nqc | |
1235 | |
1236 " NSIS | |
1237 au BufNewFile,BufRead *.nsi setf nsis | |
1238 | |
1239 " OCAML | |
1240 au BufNewFile,BufRead *.ml,*.mli,*.mll,*.mly setf ocaml | |
1241 | |
1242 " Occam | |
1243 au BufNewFile,BufRead *.occ setf occam | |
1244 | |
1245 " Omnimark | |
1246 au BufNewFile,BufRead *.xom,*.xin setf omnimark | |
1247 | |
1248 " OpenROAD | |
1249 au BufNewFile,BufRead *.or setf openroad | |
1250 | |
1251 " OPL | |
1252 au BufNewFile,BufRead *.[Oo][Pp][Ll] setf opl | |
1253 | |
1254 " Oracle config file | |
1255 au BufNewFile,BufRead *.ora setf ora | |
1256 | |
1257 " Packet filter conf | |
1258 au BufNewFile,BufRead pf.conf setf pf | |
1259 | |
375 | 1260 " Pam conf |
1261 au BufNewFile,BufRead /etc/pam.conf setf pamconf | |
1262 | |
7 | 1263 " PApp |
1264 au BufNewFile,BufRead *.papp,*.pxml,*.pxsl setf papp | |
1265 | |
389 | 1266 " Password file |
1668 | 1267 au BufNewFile,BufRead /etc/passwd,/etc/passwd-,/etc/passwd.edit,/etc/shadow,/etc/shadow-,/var/backups/passwd.bak,/var/backups/shadow.bak setf passwd |
389 | 1268 |
7 | 1269 " Pascal (also *.p) |
1270 au BufNewFile,BufRead *.pas setf pascal | |
1271 | |
1272 " Delphi project file | |
1273 au BufNewFile,BufRead *.dpr setf pascal | |
1274 | |
1648 | 1275 " PDF |
1276 au BufNewFile,BufRead *.pdf setf pdf | |
1277 | |
7 | 1278 " Perl |
1279 if has("fname_case") | |
216 | 1280 au BufNewFile,BufRead *.pl,*.PL call s:FTpl() |
7 | 1281 else |
216 | 1282 au BufNewFile,BufRead *.pl call s:FTpl() |
7 | 1283 endif |
2034 | 1284 au BufNewFile,BufRead *.plx,*.al setf perl |
7 | 1285 |
1219 | 1286 func! s:FTpl() |
7 | 1287 if exists("g:filetype_pl") |
1288 exe "setf " . g:filetype_pl | |
1289 else | |
1290 " recognize Prolog by specific text in the first non-empty line | |
1291 " require a blank after the '%' because Perl uses "%list" and "%translate" | |
1292 let l = getline(nextnonblank(1)) | |
1293 if l =~ '\<prolog\>' || l =~ '^\s*\(%\+\(\s\|$\)\|/\*\)' || l =~ ':-' | |
1294 setf prolog | |
1295 else | |
1296 setf perl | |
1297 endif | |
1298 endif | |
1219 | 1299 endfunc |
7 | 1300 |
1301 " Perl, XPM or XPM2 | |
1302 au BufNewFile,BufRead *.pm | |
1303 \ if getline(1) =~ "XPM2" | | |
1304 \ setf xpm2 | | |
1305 \ elseif getline(1) =~ "XPM" | | |
1306 \ setf xpm | | |
1307 \ else | | |
1308 \ setf perl | | |
1309 \ endif | |
1310 | |
1311 " Perl POD | |
1312 au BufNewFile,BufRead *.pod setf pod | |
1313 | |
850 | 1314 " Php, php3, php4, etc. |
1648 | 1315 " Also Phtml (was used for PHP 2 in the past) |
1316 " Also .ctp for Cake template file | |
1317 au BufNewFile,BufRead *.php,*.php\d,*.phtml,*.ctp setf php | |
7 | 1318 |
1319 " Pike | |
1320 au BufNewFile,BufRead *.pike,*.lpc,*.ulpc,*.pmod setf pike | |
1321 | |
1322 " Pinfo config | |
1323 au BufNewFile,BufRead */etc/pinforc,*/.pinforc setf pinfo | |
1324 | |
1325 " Palm Resource compiler | |
1326 au BufNewFile,BufRead *.rcp setf pilrc | |
1327 | |
1328 " Pine config | |
1329 au BufNewFile,BufRead .pinerc,pinerc,.pinercex,pinercex setf pine | |
1330 | |
1331 " PL/M (also: *.inp) | |
1332 au BufNewFile,BufRead *.plm,*.p36,*.pac setf plm | |
1333 | |
1334 " PL/SQL | |
1335 au BufNewFile,BufRead *.pls,*.plsql setf plsql | |
1336 | |
1337 " PLP | |
1338 au BufNewFile,BufRead *.plp setf plp | |
1339 | |
1340 " PO and PO template (GNU gettext) | |
1341 au BufNewFile,BufRead *.po,*.pot setf po | |
1342 | |
1343 " Postfix main config | |
1344 au BufNewFile,BufRead main.cf setf pfmain | |
1345 | |
1346 " PostScript (+ font files, encapsulated PostScript, Adobe Illustrator) | |
1347 au BufNewFile,BufRead *.ps,*.pfa,*.afm,*.eps,*.epsf,*.epsi,*.ai setf postscr | |
1348 | |
1349 " PostScript Printer Description | |
1350 au BufNewFile,BufRead *.ppd setf ppd | |
1351 | |
1352 " Povray | |
1353 au BufNewFile,BufRead *.pov setf pov | |
1354 | |
1355 " Povray configuration | |
1356 au BufNewFile,BufRead .povrayrc setf povini | |
1357 | |
1358 " Povray, PHP or assembly | |
216 | 1359 au BufNewFile,BufRead *.inc call s:FTinc() |
7 | 1360 |
1219 | 1361 func! s:FTinc() |
7 | 1362 if exists("g:filetype_inc") |
1363 exe "setf " . g:filetype_inc | |
1364 else | |
1365 let lines = getline(1).getline(2).getline(3) | |
1366 if lines =~? "perlscript" | |
1367 setf aspperl | |
1368 elseif lines =~ "<%" | |
1369 setf aspvbs | |
1370 elseif lines =~ "<?" | |
1371 setf php | |
1372 else | |
216 | 1373 call s:FTasmsyntax() |
7 | 1374 if exists("b:asmsyntax") |
1698 | 1375 exe "setf " . fnameescape(b:asmsyntax) |
7 | 1376 else |
1377 setf pov | |
1378 endif | |
1379 endif | |
1380 endif | |
1219 | 1381 endfunc |
7 | 1382 |
1383 " Printcap and Termcap | |
1384 au BufNewFile,BufRead *printcap | |
1385 \ let b:ptcap_type = "print" | setf ptcap | |
1386 au BufNewFile,BufRead *termcap | |
1387 \ let b:ptcap_type = "term" | setf ptcap | |
1388 | |
1389 " PCCTS / ANTRL | |
1390 "au BufNewFile,BufRead *.g setf antrl | |
1391 au BufNewFile,BufRead *.g setf pccts | |
1392 | |
1393 " PPWizard | |
1394 au BufNewFile,BufRead *.it,*.ih setf ppwiz | |
1395 | |
2152 | 1396 " Obj 3D file format |
1397 " TODO: is there a way to avoid MS-Windows Object files? | |
1398 au BufNewFile,BufRead *.obj setf obj | |
1399 | |
7 | 1400 " Oracle Pro*C/C++ |
1287 | 1401 au BufNewFile,BufRead *.pc setf proc |
7 | 1402 |
1125 | 1403 " Privoxy actions file |
1404 au BufNewFile,BufRead *.action setf privoxy | |
1405 | |
7 | 1406 " Procmail |
1407 au BufNewFile,BufRead .procmail,.procmailrc setf procmail | |
1408 | |
1409 " Progress or CWEB | |
216 | 1410 au BufNewFile,BufRead *.w call s:FTprogress_cweb() |
7 | 1411 |
1219 | 1412 func! s:FTprogress_cweb() |
7 | 1413 if exists("g:filetype_w") |
1414 exe "setf " . g:filetype_w | |
1415 return | |
1416 endif | |
1417 if getline(1) =~ '&ANALYZE' || getline(3) =~ '&GLOBAL-DEFINE' | |
1418 setf progress | |
1419 else | |
1420 setf cweb | |
1421 endif | |
1219 | 1422 endfunc |
7 | 1423 |
1424 " Progress or assembly | |
216 | 1425 au BufNewFile,BufRead *.i call s:FTprogress_asm() |
7 | 1426 |
1219 | 1427 func! s:FTprogress_asm() |
7 | 1428 if exists("g:filetype_i") |
1429 exe "setf " . g:filetype_i | |
1430 return | |
1431 endif | |
1432 " This function checks for an assembly comment the first ten lines. | |
1433 " If not found, assume Progress. | |
1434 let lnum = 1 | |
500 | 1435 while lnum <= 10 && lnum < line('$') |
7 | 1436 let line = getline(lnum) |
1437 if line =~ '^\s*;' || line =~ '^\*' | |
216 | 1438 call s:FTasm() |
7 | 1439 return |
1440 elseif line !~ '^\s*$' || line =~ '^/\*' | |
1441 " Not an empty line: Doesn't look like valid assembly code. | |
1442 " Or it looks like a Progress /* comment | |
1443 break | |
1444 endif | |
1445 let lnum = lnum + 1 | |
1446 endw | |
1447 setf progress | |
1219 | 1448 endfunc |
7 | 1449 |
1450 " Progress or Pascal | |
216 | 1451 au BufNewFile,BufRead *.p call s:FTprogress_pascal() |
7 | 1452 |
1219 | 1453 func! s:FTprogress_pascal() |
7 | 1454 if exists("g:filetype_p") |
1455 exe "setf " . g:filetype_p | |
1456 return | |
1457 endif | |
1458 " This function checks for valid Pascal syntax in the first ten lines. | |
1459 " Look for either an opening comment or a program start. | |
1460 " If not found, assume Progress. | |
1461 let lnum = 1 | |
500 | 1462 while lnum <= 10 && lnum < line('$') |
7 | 1463 let line = getline(lnum) |
500 | 1464 if line =~ '^\s*\(program\|unit\|procedure\|function\|const\|type\|var\)\>' |
7 | 1465 \ || line =~ '^\s*{' || line =~ '^\s*(\*' |
1466 setf pascal | |
1467 return | |
1468 elseif line !~ '^\s*$' || line =~ '^/\*' | |
1469 " Not an empty line: Doesn't look like valid Pascal code. | |
1470 " Or it looks like a Progress /* comment | |
1471 break | |
1472 endif | |
1473 let lnum = lnum + 1 | |
1474 endw | |
1475 setf progress | |
1219 | 1476 endfunc |
7 | 1477 |
1478 | |
1479 " Software Distributor Product Specification File (POSIX 1387.2-1995) | |
1480 au BufNewFile,BufRead *.psf setf psf | |
1481 au BufNewFile,BufRead INDEX,INFO | |
1482 \ if getline(1) =~ '^\s*\(distribution\|installed_software\|root\|bundle\|product\)\s*$' | | |
1483 \ setf psf | | |
1484 \ endif | |
1485 | |
1486 " Prolog | |
1487 au BufNewFile,BufRead *.pdb setf prolog | |
1488 | |
1648 | 1489 " Promela |
1490 au BufNewFile,BufRead *.pml setf promela | |
1491 | |
389 | 1492 " Protocols |
1493 au BufNewFile,BufRead /etc/protocols setf protocols | |
1494 | |
7 | 1495 " Pyrex |
1496 au BufNewFile,BufRead *.pyx,*.pxd setf pyrex | |
1497 | |
1498 " Python | |
1499 au BufNewFile,BufRead *.py,*.pyw setf python | |
1500 | |
1676 | 1501 " Quixote (Python-based web framework) |
1502 au BufNewFile,BufRead *.ptl setf python | |
1503 | |
7 | 1504 " Radiance |
1505 au BufNewFile,BufRead *.rad,*.mat setf radiance | |
1506 | |
1507 " Ratpoison config/command files | |
1508 au BufNewFile,BufRead .ratpoisonrc,ratpoisonrc setf ratpoison | |
1509 | |
1510 " RCS file | |
1511 au BufNewFile,BufRead *\,v setf rcs | |
1512 | |
1513 " Readline | |
237 | 1514 au BufNewFile,BufRead .inputrc,inputrc setf readline |
7 | 1515 |
1516 " Registry for MS-Windows | |
1517 au BufNewFile,BufRead *.reg | |
1518 \ if getline(1) =~? '^REGEDIT[0-9]*\s*$\|^Windows Registry Editor Version \d*\.\d*\s*$' | setf registry | endif | |
1519 | |
1520 " Renderman Interface Bytestream | |
1521 au BufNewFile,BufRead *.rib setf rib | |
1522 | |
1523 " Rexx | |
1648 | 1524 au BufNewFile,BufRead *.rexx,*.rex,*.jrexx,*.rxj,*.orx setf rexx |
7 | 1525 |
1526 " R (Splus) | |
836 | 1527 if has("fname_case") |
1528 au BufNewFile,BufRead *.s,*.S setf r | |
1529 else | |
1530 au BufNewFile,BufRead *.s setf r | |
1531 endif | |
7 | 1532 |
699 | 1533 " R Help file |
836 | 1534 if has("fname_case") |
1535 au BufNewFile,BufRead *.rd,*.Rd setf rhelp | |
1536 else | |
1537 au BufNewFile,BufRead *.rd setf rhelp | |
1538 endif | |
1539 | |
1540 " R noweb file | |
1541 if has("fname_case") | |
1542 au BufNewFile,BufRead *.Rnw,*.rnw,*.Snw,*.snw setf rnoweb | |
1543 else | |
1544 au BufNewFile,BufRead *.rnw,*.snw setf rnoweb | |
1545 endif | |
699 | 1546 |
7 | 1547 " Rexx, Rebol or R |
216 | 1548 au BufNewFile,BufRead *.r,*.R call s:FTr() |
7 | 1549 |
1219 | 1550 func! s:FTr() |
1125 | 1551 let max = line("$") > 50 ? 50 : line("$") |
1552 | |
1553 for n in range(1, max) | |
1554 " Rebol is easy to recognize, check for that first | |
1648 | 1555 if getline(n) =~? '\<REBOL\>' |
1125 | 1556 setf rebol |
1557 return | |
7 | 1558 endif |
1125 | 1559 endfor |
1560 | |
1561 for n in range(1, max) | |
1562 " R has # comments | |
1563 if getline(n) =~ '^\s*#' | |
1564 setf r | |
1565 return | |
1566 endif | |
1567 " Rexx has /* comments */ | |
1568 if getline(n) =~ '^\s*/\*' | |
7 | 1569 setf rexx |
1125 | 1570 return |
7 | 1571 endif |
1125 | 1572 endfor |
1573 | |
1574 " Nothing recognized, assume Rexx | |
1575 setf rexx | |
1219 | 1576 endfunc |
7 | 1577 |
1578 " Remind | |
216 | 1579 au BufNewFile,BufRead .reminders* call s:StarSetf('remind') |
2034 | 1580 au BufNewFile,BufRead *.remind,*.rem setf remind |
7 | 1581 |
1582 " Resolv.conf | |
1583 au BufNewFile,BufRead resolv.conf setf resolv | |
1584 | |
1585 " Relax NG Compact | |
1586 au BufNewFile,BufRead *.rnc setf rnc | |
1587 | |
1588 " RPL/2 | |
1589 au BufNewFile,BufRead *.rpl setf rpl | |
1590 | |
1591 " Robots.txt | |
1592 au BufNewFile,BufRead robots.txt setf robots | |
1593 | |
1594 " Rpcgen | |
1595 au BufNewFile,BufRead *.x setf rpcgen | |
1596 | |
1597 " reStructuredText Documentation Format | |
1598 au BufNewFile,BufRead *.rst setf rst | |
1599 | |
1600 " RTF | |
1601 au BufNewFile,BufRead *.rtf setf rtf | |
1602 | |
1676 | 1603 " Interactive Ruby shell |
1604 au BufNewFile,BufRead .irbrc,irbrc setf ruby | |
1605 | |
7 | 1606 " Ruby |
1607 au BufNewFile,BufRead *.rb,*.rbw,*.gem,*.gemspec setf ruby | |
1608 | |
1219 | 1609 " Ruby on Rails |
1610 au BufNewFile,BufRead *.builder,*.rxml,*.rjs setf ruby | |
1611 | |
1612 " Rantfile and Rakefile is like Ruby | |
1613 au BufNewFile,BufRead [rR]antfile,*.rant,[rR]akefile,*.rake setf ruby | |
557 | 1614 |
2034 | 1615 " S-lang (or shader language, or SmallLisp) |
7 | 1616 au BufNewFile,BufRead *.sl setf slang |
1617 | |
1618 " Samba config | |
1619 au BufNewFile,BufRead smb.conf setf samba | |
1620 | |
1621 " SAS script | |
1622 au BufNewFile,BufRead *.sas setf sas | |
1623 | |
1668 | 1624 " Sass |
1625 au BufNewFile,BufRead *.sass setf sass | |
1626 | |
7 | 1627 " Sather |
1628 au BufNewFile,BufRead *.sa setf sather | |
1629 | |
1630 " Scilab | |
809 | 1631 au BufNewFile,BufRead *.sci,*.sce setf scilab |
7 | 1632 |
1125 | 1633 " SD: Streaming Descriptors |
1634 au BufNewFile,BufRead *.sd setf sd | |
1635 | |
7 | 1636 " SDL |
1637 au BufNewFile,BufRead *.sdl,*.pr setf sdl | |
1638 | |
1639 " sed | |
1640 au BufNewFile,BufRead *.sed setf sed | |
1641 | |
36 | 1642 " Sieve (RFC 3028) |
1643 au BufNewFile,BufRead *.siv setf sieve | |
1644 | |
7 | 1645 " Sendmail |
1646 au BufNewFile,BufRead sendmail.cf setf sm | |
1647 | |
1648 | 1648 " Sendmail .mc files are actually m4. Could also be MS Message text file. |
1649 au BufNewFile,BufRead *.mc call s:McSetf() | |
1650 | |
1651 func! s:McSetf() | |
1652 " Rely on the file to start with a comment. | |
1653 " MS message text files use ';', Sendmail files use '#' or 'dnl' | |
1654 for lnum in range(1, min([line("$"), 20])) | |
1655 let line = getline(lnum) | |
1656 if line =~ '^\s*\(#\|dnl\)' | |
1657 setf m4 " Sendmail .mc file | |
1658 return | |
1659 elseif line =~ '^\s*;' | |
1660 setf msmessages " MS Message text file | |
1661 return | |
1662 endif | |
1663 endfor | |
1664 setf m4 " Default: Sendmail .mc file | |
1665 endfunc | |
7 | 1666 |
389 | 1667 " Services |
1668 au BufNewFile,BufRead /etc/services setf services | |
1669 | |
1670 " Service Location config | |
1671 au BufNewFile,BufRead /etc/slp.conf setf slpconf | |
1672 | |
1673 " Service Location registration | |
1674 au BufNewFile,BufRead /etc/slp.reg setf slpreg | |
1675 | |
1676 " Service Location SPI | |
1677 au BufNewFile,BufRead /etc/slp.spi setf slpspi | |
1678 | |
1679 " Setserial config | |
1680 au BufNewFile,BufRead /etc/serial.conf setf setserial | |
1681 | |
7 | 1682 " SGML |
1683 au BufNewFile,BufRead *.sgm,*.sgml | |
1684 \ if getline(1).getline(2).getline(3).getline(4).getline(5) =~? 'linuxdoc' | | |
1685 \ setf sgmllnx | | |
1686 \ elseif getline(1) =~ '<!DOCTYPE.*DocBook' || getline(2) =~ '<!DOCTYPE.*DocBook' | | |
1687 \ let b:docbk_type="sgml" | | |
1688 \ setf docbk | | |
1689 \ else | | |
1690 \ setf sgml | | |
1691 \ endif | |
1692 | |
1693 " SGMLDECL | |
1694 au BufNewFile,BufRead *.decl,*.dcl,*.dec | |
1695 \ if getline(1).getline(2).getline(3) =~? '^<!SGML' | | |
1696 \ setf sgmldecl | | |
1697 \ endif | |
1698 | |
1699 " SGML catalog file | |
216 | 1700 au BufNewFile,BufRead catalog setf catalog |
1701 au BufNewFile,BufRead sgml.catalog* call s:StarSetf('catalog') | |
7 | 1702 |
1703 " Shell scripts (sh, ksh, bash, bash2, csh); Allow .profile_foo etc. | |
1704 " Gentoo ebuilds are actually bash scripts | |
1705 au BufNewFile,BufRead .bashrc*,bashrc,bash.bashrc,.bash_profile*,.bash_logout*,*.bash,*.ebuild call SetFileTypeSH("bash") | |
1706 au BufNewFile,BufRead .kshrc*,*.ksh call SetFileTypeSH("ksh") | |
1707 au BufNewFile,BufRead /etc/profile,.profile*,*.sh,*.env call SetFileTypeSH(getline(1)) | |
1708 | |
216 | 1709 " Also called from scripts.vim. |
1219 | 1710 func! SetFileTypeSH(name) |
216 | 1711 if expand("<amatch>") =~ g:ft_ignore_pat |
1712 return | |
1713 endif | |
2034 | 1714 if a:name =~ '\<csh\>' |
1715 " Some .sh scripts contain #!/bin/csh. | |
1716 call SetFileTypeShell("csh") | |
1717 return | |
1718 elseif a:name =~ '\<tcsh\>' | |
1719 " Some .sh scripts contain #!/bin/tcsh. | |
1720 call SetFileTypeShell("tcsh") | |
1721 return | |
1722 elseif a:name =~ '\<ksh\>' | |
7 | 1723 let b:is_kornshell = 1 |
1724 if exists("b:is_bash") | |
1725 unlet b:is_bash | |
1726 endif | |
1727 if exists("b:is_sh") | |
1728 unlet b:is_sh | |
1729 endif | |
1730 elseif exists("g:bash_is_sh") || a:name =~ '\<bash\>' || a:name =~ '\<bash2\>' | |
1731 let b:is_bash = 1 | |
1732 if exists("b:is_kornshell") | |
1733 unlet b:is_kornshell | |
1734 endif | |
1735 if exists("b:is_sh") | |
1736 unlet b:is_sh | |
1737 endif | |
1738 elseif a:name =~ '\<sh\>' | |
1739 let b:is_sh = 1 | |
1740 if exists("b:is_kornshell") | |
1741 unlet b:is_kornshell | |
1742 endif | |
1743 if exists("b:is_bash") | |
1744 unlet b:is_bash | |
1745 endif | |
1746 endif | |
26 | 1747 call SetFileTypeShell("sh") |
1219 | 1748 endfunc |
26 | 1749 |
1750 " For shell-like file types, check for an "exec" command hidden in a comment, | |
1751 " as used for Tcl. | |
216 | 1752 " Also called from scripts.vim, thus can't be local to this script. |
1219 | 1753 func! SetFileTypeShell(name) |
216 | 1754 if expand("<amatch>") =~ g:ft_ignore_pat |
1755 return | |
1756 endif | |
26 | 1757 let l = 2 |
1758 while l < 20 && l < line("$") && getline(l) =~ '^\s*\(#\|$\)' | |
1759 " Skip empty and comment lines. | |
1760 let l = l + 1 | |
1761 endwhile | |
1762 if l < line("$") && getline(l) =~ '\s*exec\s' && getline(l - 1) =~ '^\s*#.*\\$' | |
1763 " Found an "exec" line after a comment with continuation | |
1764 let n = substitute(getline(l),'\s*exec\s\+\([^ ]*/\)\=', '', '') | |
1765 if n =~ '\<tclsh\|\<wish' | |
1766 setf tcl | |
1767 return | |
1768 endif | |
1769 endif | |
1770 exe "setf " . a:name | |
1219 | 1771 endfunc |
7 | 1772 |
1773 " tcsh scripts | |
26 | 1774 au BufNewFile,BufRead .tcshrc*,*.tcsh,tcsh.tcshrc,tcsh.login call SetFileTypeShell("tcsh") |
7 | 1775 |
1776 " csh scripts, but might also be tcsh scripts (on some systems csh is tcsh) | |
216 | 1777 au BufNewFile,BufRead .login*,.cshrc*,csh.cshrc,csh.login,csh.logout,*.csh,.alias call s:CSH() |
7 | 1778 |
1219 | 1779 func! s:CSH() |
7 | 1780 if exists("g:filetype_csh") |
26 | 1781 call SetFileTypeShell(g:filetype_csh) |
7 | 1782 elseif &shell =~ "tcsh" |
26 | 1783 call SetFileTypeShell("tcsh") |
7 | 1784 else |
26 | 1785 call SetFileTypeShell("csh") |
7 | 1786 endif |
1219 | 1787 endfunc |
7 | 1788 |
1789 " Z-Shell script | |
216 | 1790 au BufNewFile,BufRead .zprofile,/etc/zprofile,.zfbfmarks setf zsh |
1791 au BufNewFile,BufRead .zsh*,.zlog*,.zcompdump* call s:StarSetf('zsh') | |
1698 | 1792 au BufNewFile,BufRead *.zsh setf zsh |
7 | 1793 |
1794 " Scheme | |
1795 au BufNewFile,BufRead *.scm,*.ss setf scheme | |
1796 | |
1797 " Screen RC | |
1798 au BufNewFile,BufRead .screenrc,screenrc setf screen | |
1799 | |
1800 " Simula | |
1801 au BufNewFile,BufRead *.sim setf simula | |
1802 | |
1803 " SINDA | |
1804 au BufNewFile,BufRead *.sin,*.s85 setf sinda | |
1805 | |
819 | 1806 " SiSU |
857 | 1807 au BufNewFile,BufRead *.sst,*.ssm,*.ssi,*.-sst,*._sst setf sisu |
819 | 1808 au BufNewFile,BufRead *.sst.meta,*.-sst.meta,*._sst.meta setf sisu |
1809 | |
7 | 1810 " SKILL |
336 | 1811 au BufNewFile,BufRead *.il,*.ils,*.cdf setf skill |
7 | 1812 |
1813 " SLRN | |
1814 au BufNewFile,BufRead .slrnrc setf slrnrc | |
1815 au BufNewFile,BufRead *.score setf slrnsc | |
1816 | |
271 | 1817 " Smalltalk (and TeX) |
1818 au BufNewFile,BufRead *.st setf st | |
1819 au BufNewFile,BufRead *.cls | |
1820 \ if getline(1) =~ '^%' | | |
1821 \ setf tex | | |
1822 \ else | | |
1823 \ setf st | | |
1824 \ endif | |
7 | 1825 |
1826 " Smarty templates | |
1827 au BufNewFile,BufRead *.tpl setf smarty | |
1828 | |
1829 " SMIL or XML | |
1830 au BufNewFile,BufRead *.smil | |
1831 \ if getline(1) =~ '<?\s*xml.*?>' | | |
1832 \ setf xml | | |
1833 \ else | | |
1834 \ setf smil | | |
1835 \ endif | |
1836 | |
1837 " SMIL or SNMP MIB file | |
1838 au BufNewFile,BufRead *.smi | |
1839 \ if getline(1) =~ '\<smil\>' | | |
1840 \ setf smil | | |
1841 \ else | | |
1842 \ setf mib | | |
1843 \ endif | |
1844 | |
1845 " SMITH | |
1846 au BufNewFile,BufRead *.smt,*.smith setf smith | |
1847 | |
857 | 1848 " Snobol4 and spitbol |
1849 au BufNewFile,BufRead *.sno,*.spt setf snobol4 | |
7 | 1850 |
1851 " SNMP MIB files | |
1852 au BufNewFile,BufRead *.mib,*.my setf mib | |
1853 | |
1854 " Snort Configuration | |
1219 | 1855 au BufNewFile,BufRead *.hog,snort.conf,vision.conf setf hog |
1856 au BufNewFile,BufRead *.rules call s:FTRules() | |
1857 | |
1858 let s:ft_rules_udev_rules_pattern = '^\s*\cudev_rules\s*=\s*"\([^"]\{-1,}\)/*".*' | |
1859 func! s:FTRules() | |
2034 | 1860 let path = expand('<amatch>:p') |
1861 if path =~ '^/etc/udev/\%(rules\.d/\)\=.*\.rules$' | |
1648 | 1862 setf udevrules |
1863 return | |
1864 endif | |
2034 | 1865 if path =~ '^/etc/ufw/' |
1866 setf conf " Better than hog | |
1867 return | |
1868 endif | |
1219 | 1869 try |
1870 let config_lines = readfile('/etc/udev/udev.conf') | |
1871 catch /^Vim\%((\a\+)\)\=:E484/ | |
1872 setf hog | |
1873 return | |
1874 endtry | |
1648 | 1875 let dir = expand('<amatch>:p:h') |
1219 | 1876 for line in config_lines |
1877 if line =~ s:ft_rules_udev_rules_pattern | |
1878 let udev_rules = substitute(line, s:ft_rules_udev_rules_pattern, '\1', "") | |
1648 | 1879 if dir == udev_rules |
1219 | 1880 setf udevrules |
1881 endif | |
1882 break | |
1883 endif | |
1884 endfor | |
1885 setf hog | |
1886 endfunc | |
1887 | |
7 | 1888 |
1889 " Spec (Linux RPM) | |
1890 au BufNewFile,BufRead *.spec setf spec | |
1891 | |
1892 " Speedup (AspenTech plant simulator) | |
1893 au BufNewFile,BufRead *.speedup,*.spdata,*.spd setf spup | |
1894 | |
1895 " Slice | |
1896 au BufNewFile,BufRead *.ice setf slice | |
1897 | |
1898 " Spice | |
1899 au BufNewFile,BufRead *.sp,*.spice setf spice | |
1900 | |
1901 " Spyce | |
1902 au BufNewFile,BufRead *.spy,*.spi setf spyce | |
1903 | |
1904 " Squid | |
1905 au BufNewFile,BufRead squid.conf setf squid | |
1906 | |
22 | 1907 " SQL for Oracle Designer |
1908 au BufNewFile,BufRead *.tyb,*.typ,*.tyc,*.pkb,*.pks setf sql | |
1909 | |
1910 " SQL | |
216 | 1911 au BufNewFile,BufRead *.sql call s:SQL() |
22 | 1912 |
1219 | 1913 func! s:SQL() |
22 | 1914 if exists("g:filetype_sql") |
1915 exe "setf " . g:filetype_sql | |
1916 else | |
1917 setf sql | |
1918 endif | |
1219 | 1919 endfunc |
7 | 1920 |
1921 " SQLJ | |
1922 au BufNewFile,BufRead *.sqlj setf sqlj | |
1923 | |
1924 " SQR | |
1925 au BufNewFile,BufRead *.sqr,*.sqi setf sqr | |
1926 | |
1927 " OpenSSH configuration | |
1928 au BufNewFile,BufRead ssh_config,*/.ssh/config setf sshconfig | |
1929 | |
1930 " OpenSSH server configuration | |
1931 au BufNewFile,BufRead sshd_config setf sshdconfig | |
1932 | |
831 | 1933 " Stata |
1934 au BufNewFile,BufRead *.ado,*.class,*.do,*.imata,*.mata setf stata | |
1935 | |
1936 " SMCL | |
1937 au BufNewFile,BufRead *.hlp,*.ihlp,*.smcl setf smcl | |
1938 | |
7 | 1939 " Stored Procedures |
1940 au BufNewFile,BufRead *.stp setf stp | |
1941 | |
1942 " Standard ML | |
1943 au BufNewFile,BufRead *.sml setf sml | |
1944 | |
1648 | 1945 " Sratus VOS command macro |
1946 au BufNewFile,BufRead *.cm setf voscm | |
1947 | |
375 | 1948 " Sysctl |
1949 au BufNewFile,BufRead /etc/sysctl.conf setf sysctl | |
1950 | |
2034 | 1951 " Synopsys Design Constraints |
1952 au BufNewFile,BufRead *.sdc setf sdc | |
1953 | |
39 | 1954 " Sudoers |
1955 au BufNewFile,BufRead /etc/sudoers,sudoers.tmp setf sudoers | |
1956 | |
2152 | 1957 " SVG (Scalable Vector Graphics) |
1958 au BufNewFile,BufRead *.svg setf svg | |
1959 | |
826 | 1960 " If the file has an extension of 't' and is in a directory 't' then it is |
1961 " almost certainly a Perl test file. | |
557 | 1962 " If the first line starts with '#' and contains 'perl' it's probably a Perl |
1963 " file. | |
826 | 1964 " (Slow test) If a file contains a 'use' statement then it is almost certainly |
1965 " a Perl file. | |
1219 | 1966 func! s:FTperl() |
826 | 1967 if expand("%:e") == 't' && expand("%:p:h:t") == 't' |
1968 setf perl | |
1969 return 1 | |
1970 endif | |
557 | 1971 if getline(1)[0] == '#' && getline(1) =~ 'perl' |
1972 setf perl | |
1973 return 1 | |
1974 endif | |
826 | 1975 if search('^use\s\s*\k', 'nc', 30) |
1976 setf perl | |
1977 return 1 | |
1978 endif | |
557 | 1979 return 0 |
1219 | 1980 endfunc |
557 | 1981 |
1982 " Tads (or Nroff or Perl test file) | |
7 | 1983 au BufNewFile,BufRead *.t |
557 | 1984 \ if !s:FTnroff() && !s:FTperl() | setf tads | endif |
7 | 1985 |
1986 " Tags | |
1987 au BufNewFile,BufRead tags setf tags | |
1988 | |
1989 " TAK | |
1990 au BufNewFile,BufRead *.tak setf tak | |
1991 | |
2034 | 1992 " Task |
1993 au BufRead,BufNewFile {pending,completed,undo}.data setf taskdata | |
1994 au BufRead,BufNewFile *.task setf taskedit | |
1995 | |
557 | 1996 " Tcl (JACL too) |
1997 au BufNewFile,BufRead *.tcl,*.tk,*.itcl,*.itk,*.jacl setf tcl | |
7 | 1998 |
1999 " TealInfo | |
2000 au BufNewFile,BufRead *.tli setf tli | |
2001 | |
2002 " Telix Salt | |
2003 au BufNewFile,BufRead *.slt setf tsalt | |
2004 | |
2005 " Terminfo | |
2006 au BufNewFile,BufRead *.ti setf terminfo | |
2007 | |
2008 " TeX | |
378 | 2009 au BufNewFile,BufRead *.latex,*.sty,*.dtx,*.ltx,*.bbl setf tex |
2010 au BufNewFile,BufRead *.tex call s:FTtex() | |
2011 | |
800 | 2012 " Choose context, plaintex, or tex (LaTeX) based on these rules: |
2013 " 1. Check the first line of the file for "%&<format>". | |
2014 " 2. Check the first 1000 non-comment lines for LaTeX or ConTeXt keywords. | |
2015 " 3. Default to "latex" or to g:tex_flavor, can be set in user's vimrc. | |
1219 | 2016 func! s:FTtex() |
800 | 2017 let firstline = getline(1) |
2018 if firstline =~ '^%&\s*\a\+' | |
2019 let format = tolower(matchstr(firstline, '\a\+')) | |
2020 let format = substitute(format, 'pdf', '', '') | |
2021 if format == 'tex' | |
2022 let format = 'plain' | |
378 | 2023 endif |
800 | 2024 else |
2025 " Default value, may be changed later: | |
2026 let format = exists("g:tex_flavor") ? g:tex_flavor : 'plain' | |
2027 " Save position, go to the top of the file, find first non-comment line. | |
2028 let save_cursor = getpos('.') | |
2029 call cursor(1,1) | |
2030 let firstNC = search('^\s*[^[:space:]%]', 'c', 1000) | |
2031 if firstNC " Check the next thousand lines for a LaTeX or ConTeXt keyword. | |
2032 let lpat = 'documentclass\>\|usepackage\>\|begin{\|newcommand\>\|renewcommand\>' | |
2033 let cpat = 'start\a\+\|setup\a\+\|usemodule\|enablemode\|enableregime\|setvariables\|useencoding\|usesymbols\|stelle\a\+\|verwende\a\+\|stel\a\+\|gebruik\a\+\|usa\a\+\|imposta\a\+\|regle\a\+\|utilisemodule\>' | |
2034 let kwline = search('^\s*\\\%(' . lpat . '\)\|^\s*\\\(' . cpat . '\)', | |
2035 \ 'cnp', firstNC + 1000) | |
2036 if kwline == 1 " lpat matched | |
2037 let format = 'latex' | |
2038 elseif kwline == 2 " cpat matched | |
2039 let format = 'context' | |
2040 endif " If neither matched, keep default set above. | |
2041 " let lline = search('^\s*\\\%(' . lpat . '\)', 'cn', firstNC + 1000) | |
2042 " let cline = search('^\s*\\\%(' . cpat . '\)', 'cn', firstNC + 1000) | |
2043 " if cline > 0 | |
2044 " let format = 'context' | |
2045 " endif | |
2046 " if lline > 0 && (cline == 0 || cline > lline) | |
2047 " let format = 'tex' | |
2048 " endif | |
2049 endif " firstNC | |
2050 call setpos('.', save_cursor) | |
2051 endif " firstline =~ '^%&\s*\a\+' | |
694 | 2052 |
800 | 2053 " Translation from formats to file types. TODO: add AMSTeX, RevTex, others? |
2054 if format == 'plain' | |
2055 setf plaintex | |
2056 elseif format == 'context' | |
694 | 2057 setf context |
800 | 2058 else " probably LaTeX |
694 | 2059 setf tex |
2060 endif | |
800 | 2061 return |
1219 | 2062 endfunc |
378 | 2063 |
1648 | 2064 " ConTeXt |
2065 au BufNewFile,BufRead tex/context/*/*.tex,*.mkii,*.mkiv setf context | |
7 | 2066 |
2067 " Texinfo | |
2068 au BufNewFile,BufRead *.texinfo,*.texi,*.txi setf texinfo | |
2069 | |
2070 " TeX configuration | |
2071 au BufNewFile,BufRead texmf.cnf setf texmf | |
2072 | |
2073 " Tidy config | |
2074 au BufNewFile,BufRead .tidyrc,tidyrc setf tidy | |
2075 | |
2076 " TF mud client | |
2077 au BufNewFile,BufRead *.tf,.tfrc,tfrc setf tf | |
2078 | |
33 | 2079 " TPP - Text Presentation Program |
2080 au BufNewFile,BufReadPost *.tpp setf tpp | |
2081 | |
555 | 2082 " Trustees |
2083 au BufNewFile,BufRead trustees.conf setf trustees | |
2084 | |
7 | 2085 " TSS - Geometry |
2086 au BufNewFile,BufReadPost *.tssgm setf tssgm | |
2087 | |
2088 " TSS - Optics | |
2089 au BufNewFile,BufReadPost *.tssop setf tssop | |
2090 | |
2091 " TSS - Command Line (temporary) | |
2092 au BufNewFile,BufReadPost *.tsscl setf tsscl | |
2093 | |
2094 " Motif UIT/UIL files | |
2095 au BufNewFile,BufRead *.uit,*.uil setf uil | |
2096 | |
389 | 2097 " Udev conf |
2098 au BufNewFile,BufRead /etc/udev/udev.conf setf udevconf | |
2099 | |
2100 " Udev permissions | |
2101 au BufNewFile,BufRead /etc/udev/permissions.d/*.permissions setf udevperm | |
2102 " | |
2103 " Udev symlinks config | |
2104 au BufNewFile,BufRead /etc/udev/cdsymlinks.conf setf sh | |
2105 | |
7 | 2106 " UnrealScript |
2107 au BufNewFile,BufRead *.uc setf uc | |
2108 | |
375 | 2109 " Updatedb |
2110 au BufNewFile,BufRead /etc/updatedb.conf setf updatedb | |
2111 | |
836 | 2112 " Vera |
2113 au BufNewFile,BufRead *.vr,*.vri,*.vrh setf vera | |
2114 | |
7 | 2115 " Verilog HDL |
2116 au BufNewFile,BufRead *.v setf verilog | |
2117 | |
481 | 2118 " Verilog-AMS HDL |
2119 au BufNewFile,BufRead *.va,*.vams setf verilogams | |
2120 | |
7 | 2121 " VHDL |
216 | 2122 au BufNewFile,BufRead *.hdl,*.vhd,*.vhdl,*.vbe,*.vst setf vhdl |
375 | 2123 au BufNewFile,BufRead *.vhdl_[0-9]* call s:StarSetf('vhdl') |
7 | 2124 |
2125 " Vim script | |
794 | 2126 au BufNewFile,BufRead *.vim,*.vba,.exrc,_exrc setf vim |
7 | 2127 |
2128 " Viminfo file | |
2129 au BufNewFile,BufRead .viminfo,_viminfo setf viminfo | |
2130 | |
2034 | 2131 " Virata Config Script File or Drupal module |
2132 au BufRead,BufNewFile *.hw,*.module,*.pkg | |
2133 \ if getline(1) =~ '<?php' | | |
2134 \ setf php | | |
2135 \ else | | |
2136 \ setf virata | | |
2137 \ endif | |
7 | 2138 |
2139 " Visual Basic (also uses *.bas) or FORM | |
216 | 2140 au BufNewFile,BufRead *.frm call s:FTVB("form") |
7 | 2141 |
2142 " SaxBasic is close to Visual Basic | |
2143 au BufNewFile,BufRead *.sba setf vb | |
2144 | |
2145 " Vgrindefs file | |
2146 au BufNewFile,BufRead vgrindefs setf vgrindefs | |
2147 | |
2148 " VRML V1.0c | |
2149 au BufNewFile,BufRead *.wrl setf vrml | |
2150 | |
2151 " Webmacro | |
2152 au BufNewFile,BufRead *.wm setf webmacro | |
2153 | |
2154 " Wget config | |
2155 au BufNewFile,BufRead .wgetrc,wgetrc setf wget | |
2156 | |
2157 " Website MetaLanguage | |
2158 au BufNewFile,BufRead *.wml setf wml | |
2159 | |
2160 " Winbatch | |
2161 au BufNewFile,BufRead *.wbt setf winbatch | |
2162 | |
753 | 2163 " WSML |
2164 au BufNewFile,BufRead *.wsml setf wsml | |
2165 | |
7 | 2166 " WvDial |
2167 au BufNewFile,BufRead wvdial.conf,.wvdialrc setf wvdial | |
2168 | |
2169 " CVS RC file | |
2170 au BufNewFile,BufRead .cvsrc setf cvsrc | |
2171 | |
2172 " CVS commit file | |
2173 au BufNewFile,BufRead cvs\d\+ setf cvs | |
2174 | |
2175 " WEB (*.web is also used for Winbatch: Guess, based on expecting "%" comment | |
2176 " lines in a WEB file). | |
2177 au BufNewFile,BufRead *.web | |
2178 \ if getline(1)[0].getline(2)[0].getline(3)[0].getline(4)[0].getline(5)[0] =~ "%" | | |
2179 \ setf web | | |
2180 \ else | | |
2181 \ setf winbatch | | |
2182 \ endif | |
2183 | |
2184 " Windows Scripting Host and Windows Script Component | |
2185 au BufNewFile,BufRead *.ws[fc] setf wsh | |
2186 | |
1125 | 2187 " XHTML |
2188 au BufNewFile,BufRead *.xhtml,*.xht setf xhtml | |
2189 | |
7 | 2190 " X Pixmap (dynamically sets colors, use BufEnter to make it work better) |
2191 au BufEnter *.xpm | |
2192 \ if getline(1) =~ "XPM2" | | |
2193 \ setf xpm2 | | |
2194 \ else | | |
2195 \ setf xpm | | |
2196 \ endif | |
2197 au BufEnter *.xpm2 setf xpm2 | |
2198 | |
2199 " XFree86 config | |
2200 au BufNewFile,BufRead XF86Config | |
2201 \ if getline(1) =~ '\<XConfigurator\>' | | |
2202 \ let b:xf86c_xfree86_version = 3 | | |
2203 \ endif | | |
2204 \ setf xf86conf | |
2205 | |
2206 " Xorg config | |
2207 au BufNewFile,BufRead xorg.conf,xorg.conf-4 let b:xf86c_xfree86_version = 4 | setf xf86conf | |
2208 | |
375 | 2209 " Xinetd conf |
2210 au BufNewFile,BufRead /etc/xinetd.conf setf xinetd | |
2211 | |
7 | 2212 " XS Perl extension interface language |
2213 au BufNewFile,BufRead *.xs setf xs | |
2214 | |
2215 " X resources file | |
2216 au BufNewFile,BufRead .Xdefaults,.Xpdefaults,.Xresources,xdm-config,*.ad setf xdefaults | |
2217 | |
2218 " Xmath | |
2219 au BufNewFile,BufRead *.msc,*.msf setf xmath | |
2220 au BufNewFile,BufRead *.ms | |
216 | 2221 \ if !s:FTnroff() | setf xmath | endif |
7 | 2222 |
1648 | 2223 " XML specific variants: docbk and xbl |
2224 au BufNewFile,BufRead *.xml call s:FTxml() | |
2225 | |
2226 func! s:FTxml() | |
2227 let n = 1 | |
2228 while n < 100 && n < line("$") | |
2229 let line = getline(n) | |
2230 if line =~ '<!DOCTYPE.*DocBook' | |
2231 let b:docbk_type = "xml" | |
2232 setf docbk | |
2233 return | |
2234 endif | |
2235 if line =~ 'xmlns:xbl="http://www.mozilla.org/xbl"' | |
2236 setf xbl | |
2237 return | |
2238 endif | |
2239 let n += 1 | |
2240 endwhile | |
2241 setf xml | |
2242 endfunc | |
7 | 2243 |
2244 " XMI (holding UML models) is also XML | |
2245 au BufNewFile,BufRead *.xmi setf xml | |
2246 | |
2247 " CSPROJ files are Visual Studio.NET's XML-based project config files | |
2248 au BufNewFile,BufRead *.csproj,*.csproj.user setf xml | |
2249 | |
2250 " Qt Linguist translation source and Qt User Interface Files are XML | |
2251 au BufNewFile,BufRead *.ts,*.ui setf xml | |
2252 | |
1125 | 2253 " TPM's are RDF-based descriptions of TeX packages (Nikolai Weibull) |
2254 au BufNewFile,BufRead *.tpm setf xml | |
2255 | |
389 | 2256 " Xdg menus |
2257 au BufNewFile,BufRead /etc/xdg/menus/*.menu setf xml | |
2258 | |
1648 | 2259 " ATI graphics driver configuration |
2260 au BufNewFile,BufRead fglrxrc setf xml | |
2261 | |
2262 " XLIFF (XML Localisation Interchange File Format) is also XML | |
2263 au BufNewFile,BufRead *.xlf setf xml | |
2264 au BufNewFile,BufRead *.xliff setf xml | |
2265 | |
2266 " X11 xmodmap (also see below) | |
2267 au BufNewFile,BufRead *Xmodmap setf xmodmap | |
2268 | |
419 | 2269 " Xquery |
2270 au BufNewFile,BufRead *.xq,*.xql,*.xqm,*.xquery,*.xqy setf xquery | |
2271 | |
7 | 2272 " XSD |
2273 au BufNewFile,BufRead *.xsd setf xsd | |
2274 | |
2275 " Xslt | |
2276 au BufNewFile,BufRead *.xsl,*.xslt setf xslt | |
2277 | |
2278 " Yacc | |
375 | 2279 au BufNewFile,BufRead *.yy setf yacc |
2280 | |
2281 " Yacc or racc | |
2282 au BufNewFile,BufRead *.y call s:FTy() | |
2283 | |
1219 | 2284 func! s:FTy() |
375 | 2285 let n = 1 |
484 | 2286 while n < 100 && n < line("$") |
2287 let line = getline(n) | |
2288 if line =~ '^\s*%' | |
2289 setf yacc | |
2290 return | |
2291 endif | |
482 | 2292 if getline(n) =~ '^\s*\(#\|class\>\)' && getline(n) !~ '^\s*#\s*include' |
375 | 2293 setf racc |
2294 return | |
2295 endif | |
2296 let n = n + 1 | |
2297 endwhile | |
2298 setf yacc | |
1219 | 2299 endfunc |
375 | 2300 |
7 | 2301 |
2302 " Yaml | |
2303 au BufNewFile,BufRead *.yaml,*.yml setf yaml | |
2304 | |
809 | 2305 " Zope |
2306 " dtml (zope dynamic template markup language), pt (zope page template), | |
2307 " cpt (zope form controller page template) | |
826 | 2308 au BufNewFile,BufRead *.dtml,*.pt,*.cpt call s:FThtml() |
809 | 2309 " zsql (zope sql method) |
2310 au BufNewFile,BufRead *.zsql call s:SQL() | |
2311 | |
7 | 2312 " Z80 assembler asz80 |
2313 au BufNewFile,BufRead *.z8a setf z8a | |
2314 | |
2315 augroup END | |
2316 | |
2317 | |
2318 " Source the user-specified filetype file, for backwards compatibility with | |
2319 " Vim 5.x. | |
216 | 2320 if exists("myfiletypefile") && filereadable(expand(myfiletypefile)) |
7 | 2321 execute "source " . myfiletypefile |
2322 endif | |
2323 | |
2324 | |
2325 " Check for "*" after loading myfiletypefile, so that scripts.vim is only used | |
2326 " when there are no matching file name extensions. | |
2327 " Don't do this for compressed files. | |
2328 augroup filetypedetect | |
2329 au BufNewFile,BufRead * | |
2330 \ if !did_filetype() && expand("<amatch>") !~ g:ft_ignore_pat | |
2331 \ | runtime! scripts.vim | endif | |
2332 au StdinReadPost * if !did_filetype() | runtime! scripts.vim | endif | |
2333 | |
2334 | |
2335 " Extra checks for when no filetype has been detected now. Mostly used for | |
2336 " patterns that end in "*". E.g., "zsh*" matches "zsh.vim", but that's a Vim | |
2337 " script file. | |
216 | 2338 " Most of these should call s:StarSetf() to avoid names ending in .gz and the |
2339 " like are used. | |
7 | 2340 |
1668 | 2341 " More Apache files. |
2342 au BufNewFile,BufRead /etc/apache2/conf.*/*,/etc/apache2/sites-*/*,/etc/apache2/mods-*/* call s:StarSetf('apache') | |
2343 | |
531 | 2344 " Asterisk config file |
856 | 2345 au BufNewFile,BufRead *asterisk/*.conf* call s:StarSetf('asterisk') |
794 | 2346 au BufNewFile,BufRead *asterisk*/*voicemail.conf* call s:StarSetf('asteriskvm') |
531 | 2347 |
1125 | 2348 " Bazaar version control |
2349 au BufNewFile,BufRead bzr_log.* setf bzr | |
2350 | |
7 | 2351 " BIND zone |
805 | 2352 au BufNewFile,BufRead */named/db.*,*/bind/db.* call s:StarSetf('bindzone') |
7 | 2353 |
2354 " Changelog | |
216 | 2355 au BufNewFile,BufRead [cC]hange[lL]og* |
2356 \ if getline(1) =~ '; urgency=' | |
2357 \| call s:StarSetf('debchangelog') | |
2358 \|else | |
2359 \| call s:StarSetf('changelog') | |
2360 \|endif | |
7 | 2361 |
2362 " Crontab | |
1668 | 2363 au BufNewFile,BufRead crontab,crontab.*,/etc/cron.d/* call s:StarSetf('crontab') |
7 | 2364 |
816 | 2365 " Debian Sources.list |
2366 au BufNewFile,BufRead /etc/apt/sources.list.d/* call s:StarSetf('debsources') | |
2367 | |
7 | 2368 " Dracula |
216 | 2369 au BufNewFile,BufRead drac.* call s:StarSetf('dracula') |
7 | 2370 |
2371 " Fvwm | |
1125 | 2372 au BufNewFile,BufRead */.fvwm/* call s:StarSetf('fvwm') |
7 | 2373 au BufNewFile,BufRead *fvwmrc*,*fvwm95*.hook |
216 | 2374 \ let b:fvwm_version = 1 | call s:StarSetf('fvwm') |
7 | 2375 au BufNewFile,BufRead *fvwm2rc* |
216 | 2376 \ if expand("<afile>:e") == "m4" |
2377 \| call s:StarSetf('fvwm2m4') | |
2378 \|else | |
2379 \| let b:fvwm_version = 2 | call s:StarSetf('fvwm') | |
2380 \|endif | |
7 | 2381 |
2034 | 2382 " Gedcom |
2383 au BufNewFile,BufRead /tmp/lltmp* call s:StarSetf('gedcom') | |
2384 | |
7 | 2385 " GTK RC |
216 | 2386 au BufNewFile,BufRead .gtkrc*,gtkrc* call s:StarSetf('gtkrc') |
7 | 2387 |
2388 " Jam | |
216 | 2389 au BufNewFile,BufRead Prl*.*,JAM*.* call s:StarSetf('jam') |
7 | 2390 |
2391 " Jargon | |
2392 au! BufNewFile,BufRead *jarg* | |
216 | 2393 \ if getline(1).getline(2).getline(3).getline(4).getline(5) =~? 'THIS IS THE JARGON FILE' |
2394 \| call s:StarSetf('jargon') | |
2395 \|endif | |
7 | 2396 |
837 | 2397 " Kconfig |
2398 au BufNewFile,BufRead Kconfig.* call s:StarSetf('kconfig') | |
2399 | |
7 | 2400 " Makefile |
216 | 2401 au BufNewFile,BufRead [mM]akefile* call s:StarSetf('make') |
7 | 2402 |
1648 | 2403 " Ruby Makefile |
2404 au BufNewFile,BufRead [rR]akefile* call s:StarSetf('ruby') | |
2405 | |
2406 " Mail (also matches muttrc.vim, so this is below the other checks) | |
2407 au BufNewFile,BufRead mutt[[:alnum:]._-]\{6\} setf mail | |
2408 | |
389 | 2409 " Modconf |
2410 au BufNewFile,BufRead /etc/modprobe.* call s:StarSetf('modconf') | |
2411 | |
7 | 2412 " Mutt setup file |
1648 | 2413 au BufNewFile,BufRead .mutt{ng,}rc*,*/.mutt{ng,}/mutt{ng,}rc* call s:StarSetf('muttrc') |
484 | 2414 au BufNewFile,BufRead mutt{ng,}rc*,Mutt{ng,}rc* call s:StarSetf('muttrc') |
7 | 2415 |
2416 " Nroff macros | |
216 | 2417 au BufNewFile,BufRead tmac.* call s:StarSetf('nroff') |
7 | 2418 |
375 | 2419 " Pam conf |
2420 au BufNewFile,BufRead /etc/pam.d/* call s:StarSetf('pamconf') | |
2421 | |
7 | 2422 " Printcap and Termcap |
2423 au BufNewFile,BufRead *printcap* | |
216 | 2424 \ if !did_filetype() |
2425 \| let b:ptcap_type = "print" | call s:StarSetf('ptcap') | |
2426 \|endif | |
7 | 2427 au BufNewFile,BufRead *termcap* |
216 | 2428 \ if !did_filetype() |
2429 \| let b:ptcap_type = "term" | call s:StarSetf('ptcap') | |
2430 \|endif | |
7 | 2431 |
2432 " Vim script | |
216 | 2433 au BufNewFile,BufRead *vimrc* call s:StarSetf('vim') |
7 | 2434 |
2435 " Subversion commit file | |
45 | 2436 au BufNewFile,BufRead svn-commit*.tmp setf svn |
7 | 2437 |
2438 " X resources file | |
216 | 2439 au BufNewFile,BufRead Xresources*,*/app-defaults/*,*/Xresources/* call s:StarSetf('xdefaults') |
7 | 2440 |
2441 " XFree86 config | |
2442 au BufNewFile,BufRead XF86Config-4* | |
216 | 2443 \ let b:xf86c_xfree86_version = 4 | call s:StarSetf('xf86conf') |
7 | 2444 au BufNewFile,BufRead XF86Config* |
216 | 2445 \ if getline(1) =~ '\<XConfigurator\>' |
2446 \| let b:xf86c_xfree86_version = 3 | |
2447 \|endif | |
2448 \|call s:StarSetf('xf86conf') | |
7 | 2449 |
2450 " X11 xmodmap | |
216 | 2451 au BufNewFile,BufRead *xmodmap* call s:StarSetf('xmodmap') |
7 | 2452 |
375 | 2453 " Xinetd conf |
2454 au BufNewFile,BufRead /etc/xinetd.d/* call s:StarSetf('xinetd') | |
2455 | |
7 | 2456 " Z-Shell script |
216 | 2457 au BufNewFile,BufRead zsh*,zlog* call s:StarSetf('zsh') |
7 | 2458 |
2459 | |
2013 | 2460 |
2461 " Use the filetype detect plugins. They may overrule any of the previously | |
2462 " detected filetypes. | |
2463 runtime! ftdetect/*.vim | |
2464 | |
2465 | |
7 | 2466 " Generic configuration file (check this last, it's just guessing!) |
2467 au BufNewFile,BufRead,StdinReadPost * | |
2468 \ if !did_filetype() && expand("<amatch>") !~ g:ft_ignore_pat | |
2469 \ && (getline(1) =~ '^#' || getline(2) =~ '^#' || getline(3) =~ '^#' | |
2470 \ || getline(4) =~ '^#' || getline(5) =~ '^#') | | |
2471 \ setf conf | | |
2472 \ endif | |
2473 | |
2474 augroup END | |
2475 | |
2476 | |
2477 " If the GUI is already running, may still need to install the Syntax menu. | |
2478 " Don't do it when the 'M' flag is included in 'guioptions'. | |
2479 if has("menu") && has("gui_running") | |
2480 \ && !exists("did_install_syntax_menu") && &guioptions !~# "M" | |
2481 source <sfile>:p:h/menu.vim | |
2482 endif | |
2483 | |
1219 | 2484 " Function called for testing all functions defined here. These are |
2485 " script-local, thus need to be executed here. | |
2486 " Returns a string with error messages (hopefully empty). | |
2487 func! TestFiletypeFuncs(testlist) | |
2488 let output = '' | |
2489 for f in a:testlist | |
2490 try | |
2491 exe f | |
2492 catch | |
2493 let output = output . "\n" . f . ": " . v:exception | |
2494 endtry | |
2495 endfor | |
2496 return output | |
2497 endfunc | |
2498 | |
7 | 2499 " Restore 'cpoptions' |
2500 let &cpo = s:cpo_save | |
2501 unlet s:cpo_save |